Go中encoding/binary包用于基础类型及合规结构体的二进制编解码,依赖指定字节序、严格顺序读写,支持文件/网络/内存等io接口,不支持指针切片映射等非固定长度类型。

在 Go 中处理二进制文件读写,encoding/binary 包是核心工具,它提供对基本类型(如 int32、uint64、float64)的确定性字节序列编解码能力,特别适合协议解析、文件格式封装、网络数据交换等场景。
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))
也可一次性写入结构体(前提是结构体满足要求):
立即学习“go语言免费学习笔记(深入)”;
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) 查看原始字节,验证字节序和布局是否符合预期。
以上就是如何在Golang中实现二进制文件读写_使用encoding/binary包处理的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号