书籍封面

Go语言精进之路:从新手到高手的编程思想、方法和技巧2

白明
  • 版权信息
  • 作者简介
  • 推荐语
  • 推荐序
  • 前言
  • 第八部分 测试、性能剖析与调试
  • 第40条 理解包内测试与包外测试的差别
  • 40.1 官方文档的“自相矛盾”
  • 40.2 包内测试与包外测试
  • 第41条 有层次地组织测试代码
  • 41.1 经典模式——平铺
  • 41.2 xUnit家族模式
  • 41.3 测试固件
  • 第42条 优先编写表驱动的测试
  • 42.1 Go测试代码的一般逻辑
  • 42.2 表驱动的测试实践
  • 42.3 表驱动测试的优点
  • 42.4 表驱动测试实践中的注意事项
  • 第43条 使用testdata管理测试依赖的外部数据文件
  • 43.1 testdata目录
  • 43.2 golden文件惯用法
  • 第44条 正确运用fake、stub和mock等辅助单元测试
  • 44.1 fake:真实组件或服务的简化实现版替身
  • 44.2 stub:对返回结果有一定预设控制能力的替身
  • 44.3 mock:专用于行为观察和验证的替身
  • 第45条 使用模糊测试让潜在bug无处遁形
  • 45.1 模糊测试在挖掘Go代码的潜在bug中的作用
  • 45.2 go-fuzz的初步工作原理
  • 45.3 go-fuzz使用方法
  • 45.4 使用go-fuzz建立模糊测试的示例
  • 45.5 让模糊测试成为“一等公民”
  • 第46条 为被测对象建立性能基准
  • 46.1 性能基准测试在Go语言中是“一等公民”
  • 46.2 顺序执行和并行执行的性能基准测试
  • 46.3 使用性能基准比较工具
  • 46.4 排除额外干扰,让基准测试更精确
  • 第47条 使用pprof对程序进行性能剖析
  • 47.1 pprof的工作原理
  • 47.2 使用pprof进行性能剖析的实例
  • 第48条 使用expvar输出度量数据,辅助定位性能瓶颈点
  • 48.1 expvar包的工作原理
  • 48.2 自定义应用通过expvar输出的度量数据
  • 48.3 输出数据的展示
  • 第49条 使用Delve调试Go代码
  • 49.1 关于调试,你首先应该知道的几件事
  • 49.2 Go调试工具的选择
  • 49.3 Delve调试基础、原理与架构
  • 49.4 并发、Coredump文件与挂接进程调试
  • 第九部分 标准库、反射与cgo
  • 第50条 理解Go TCP Socket网络编程模型
  • 50.1 TCP Socket网络编程模型
  • 50.2 TCP连接的建立
  • 50.3 Socket读写
  • 50.4 Socket属性
  • 50.5 关闭连接
  • 第51条 使用net/http包实现安全通信
  • 51.1 HTTPS:在安全传输层上运行的HTTP协议
  • 51.2 HTTPS安全传输层的工作机制
  • 51.3 非对称加密和公钥证书
  • 51.4 对服务端公钥证书的校验
  • 51.5 对客户端公钥证书的校验
  • 第52条 掌握字符集的原理和字符编码方案间的转换
  • 52.1 字符与字符集
  • 52.2 Unicode字符集的诞生与UTF-8编码方案
  • 52.3 字符编码方案间的转换
  • 第53条 掌握使用time包的正确方式
  • 53.1 时间的基础操作
  • 53.2 时间的格式化输出
  • 53.3 定时器的使用
  • 第54条 不要忽略对系统信号的处理
  • 54.1 为什么不能忽略对系统信号的处理
  • 54.2 Go语言对系统信号处理的支持
  • 54.3 使用系统信号实现程序的优雅退出
  • 第55条 使用crypto下的密码学包构建安全应用
  • 55.1 Go密码学包概览与设计原则
  • 55.2 分组密码算法
  • 55.3 公钥密码
  • 55.4 单向散列函数
  • 55.5 消息认证码
  • 55.6 数字签名
  • 55.7 随机数生成
  • 第56条 掌握bytes包和strings包的基本操作
  • 56.1 查找与替换
  • 56.2 比较
  • 56.3 分割
  • 56.4 拼接
  • 56.5 修剪与变换
  • 56.6 快速对接I/O模型
  • 第57条 理解标准库的读写模型
  • 57.1 直接读写字节序列
  • 57.2 直接读写抽象数据类型实例
  • 57.3 通过包裹类型读写数据
  • 第58条 掌握unsafe包的安全使用模式
  • 58.1 简洁的unsafe包
  • 58.2 unsafe包的典型应用
  • 58.3 正确理解unsafe.Pointer与uintptr
  • 58.4 unsafe.Pointer的安全使用模式
  • 第59条 谨慎使用reflect包提供的反射能力
  • 59.1 Go反射的三大法则
  • 59.2 反射世界的入口
  • 59.3 反射世界的出口
  • 59.4 输出参数、interface{}类型变量及反射对象的可设置性
  • 第60条 了解cgo的原理和使用开销
  • 60.1 Go调用C代码的原理
  • 60.2 在Go中使用C语言的类型
  • 60.3 在Go中链接外部C库
  • 60.4 在C中使用Go函数
  • 60.5 使用cgo的开销
  • 60.6 使用cgo代码的静态构建
  • 第十部分 工具链与工程实践
  • 第61条 使用module管理包依赖
  • 61.1 Go语言包管理演进回顾
  • 61.2 Go module:Go包依赖管理的生产标准
  • 61.3 Go module代理
  • 61.4 升级module的主版本号
  • 第62条 构建最小Go程序容器镜像
  • 62.1 镜像:继承中的创新
  • 62.2 镜像是个筐:初学者的认知
  • 62.3 理性回归:builder模式的崛起
  • 62.4 “像赛车那样减重”:追求最小镜像
  • 62.5 “要有光”:对多阶段构建的支持
  • 第63条 自定义Go包的导入路径
  • 63.1 govanityurls
  • 63.2 使用govanityurls
  • 第64条 熟练掌握Go常用工具
  • 64.1 获取与安装
  • 64.2 包或module检视
  • 64.3 构建
  • 64.4 运行与诊断
  • 64.5 格式化与静态代码检查
  • 64.6 重构
  • 64.7 查看文档
  • 64.8 代码导航与洞察
  • 第65条 使用go generate驱动代码生成
  • 65.1 go generate:Go原生的代码生成“驱动器”
  • 65.2 go generate的工作原理
  • 65.3 go generate的应用场景
  • 第66条 牢记Go的常见“陷阱”
  • 66.1 语法规范类
  • 66.2 标准库类