标准库的 bufio 包实现了带缓冲的 I/O。它对 io.Reader 或 io.Writer 进行封装,并返回一个新的 io.Reader 或 io.Writer 对象。新的 I/O 对象在原有的 io.Reader 或 io.Writer 对象之上提供缓冲功能,从而减少系统调用次数,以提高 I/O 性能。
go 库学习之 io
Go 标准库的 io 包定义了 Go 语言基本的 I/O 模型,它提供了各种与 I/O 相关的接口类型,同时也提供了一些工具类型和函数,以提供一些扩展功能。
go 库学习之 netip
在编写网络相关的程序代码时,我们经常需要处理 IP 地址。当同时需要对 IPv4/IPv6 双栈网络支持时,如何简洁、优雅地表示 IP 地址也是需要些技巧的。
这篇文章将分析 Go 库的 net/netip
包,学习 Go 标准库如何表示和处理 IP 地址/网段。
go 库学习之 errors
Go 采用的是基于 错误值比较
的错误处理机制,即通过检查返回的 error 值来判断函数/方法是否执行成功,如果执行失败,也是通过该 error 值来携带具体的错误信息。相比于其他编程语言的 异常
错误处理机制,这种 值比较
机制更加简单,它要求在程序控制流程中显式关注和处理每个错误,这样的代码往往可读性更好,也符合 Go 追求简答的设计哲学。
标准库的 errors 包为 Go 的错误处理机制提供了基础支持,这篇文章将学习 errors 包的基本用法和原理。
go 库学习之 bytes
Go 标准库中的 bytes 包提供了一系列工具来实现对 字节切片
([]byte)的操作。bytes 包和 string 包提供了类似的工具类 API,只不过 bytes 包操作的字节切片,而 strings 包操作的是字符串类型。
这篇文章将学习 bytes 包的基本使用方法。
go 库学习之 context
context 包定义了 Context 类型,通过该类型可以实现在不同流程间设置 deadline、通知取消信号、设置每请求关联值等功能。context 包简化了 Go 并发编程中不同 API/流程间的信息传递(取消信号、超时信号、每请求关联数据等都可以认为是要传递的信息)。
这篇文章主要介绍 context 包的使用及内部原理。
《Go 语言精进之路》读书笔记(10):工具链与工程实践
这篇文章学习使用 Go 语言做软件项目过程中很可能会遇到的一些工程问题的解决方法,包括使用 go module
进行 Go 包依赖管理、Go 应用容器镜像、Go 相关工具使用等。
《Go 语言精进之路》读书笔记(09):标准库、反射与 cgo
Go 拥有功能强大且质量上乘的标准库,这篇文章将介绍高频使用的标准库包,如 net/http、strings、bytes、time 等正确使用方式,以及 reflect 包、cgo 在使用时的注意事项。
《Go 语言精进之路》读书笔记(08):测试、性能剖析与调试
Go 语言推崇 面向工程
的设计哲学并自带强大的且为人所称道的工具链。这篇文章将学习 Go 在单元测试、性能测试以及代码调试方面的最佳实践方案。
《Go 语言精进之路》读书笔记(07):错误处理
Go 十分重视错误处理,它有着相对保守的设计和显式处理错误的惯例。这篇文章将聚焦 Go 中的错误处理。