Go中encoding/binary包用于基础类型及合规结构体的二进制编解码,依赖指定字节序、严格顺序读写,支持文件/网络/内存等io接口,不支持指针切片映射等非固定长度类型。
在 Go 中处理二进制文件读写,encoding/binary 包是核心工具,它提供对基本类型(如 int32、uint64、float64)的确定性字节序列编解码能力,特别适合协议解析、文件格式封装、网络数据交换等场景。
和 binary.Read 的底层逻辑binary.Write 和 binary.Read 不直接操作文件,而是作用于实现了 io.Writer 或 io.Reader 接口的任意对象(比如 *os.File、bytes.Buffer、net.Conn)。它们按指定字节序(binary.LittleEndian 或 binary.BigEndian)将 Go 值序列化为固定长度的字节流,或反向还原。注意:只支持基础类型和由它们组成的结构体(字段必须导出、无指针/切片/映射等非二进制友好类型)。
[4]byte)可直接读写;但 []byte 需自行处理长度前缀打开文件(os.Create),创建 binary.Write 所需的 io.Writer 上下文,按协议顺序写入各字段:
file, _ := os.Create("data.bin")
defer file.Close()
// 写入魔数(uint32)、版本号(uint8)、长度(uint16)、浮点数据(float64)
binary.Write(file, binary.LittleEndian, uint32(0x424C4F47)) // "GOLB" 反序
binary.Write(file, binary.LittleEndian, uint8(1))
binary.Write(file, binary.LittleEndian, uint16(1024))
binary.Write(file, binary.LittleEndian, float64(3.14159))
也可一次性写入结构体(前提是结构体满足要求):
type Header struct {
Magic uint32
Ver uint8
Len uint16
Value float64
}
hdr := Header{0x424C4F47, 1, 1024, 3.14159}
binary.Write(file, binary.LittleEndian, hdr)
读取必须与写入完全对齐:字节序一致、字段顺序一致、类型大小一致(例如 int 在 32 位/64 位系统上长度不同,应始终用 int32 或 int64 显式声明)。
binary.Read 时,传入变量地址(&v),而非值本身os.Stat 检查文件大小是否足够,避免 io.ErrUnexpectedEOF
示例读取上述 header:
file, _ := os.Open("data.bin")
defer file.Close()
var hdr Header
err := binary.Read(file, binary.LittleEndian, &hdr)
if err != nil {
log.Fatal(err)
}
fmt.Printf("%x %d %d %f\n", hdr.Magic, hdr.Ver, hdr.Len, hdr.Value)
encoding/binary 本身不支持字符串或切片,但可通过组合方式实现:
uint32),再写入字节([]byte(s));读取时先读长度 n,再用 io.ReadFull 读 n 字节,最后转 string()
[]byte;注意分配足够底层数组(可用 make([]byte, n))[16]byte 可直接读写;但 []byte 必须手动管理长度小提示:调试时可用 hex.Dump(data) 查看原始字节,验证字节序和布局是否符合预期。