Golang如何使用encoding/gob进行对象序列化_Golang gob对象序列化实践

Golang的gob包提供高效二进制序列化,适用于Go间数据交换。1. 结构体字段需大写才能被序列化;2. 使用gob.NewEncoder将对象编码到文件;3. 用gob.NewDecoder从文件恢复对象;4. 含接口时须调用gob.Register注册类型,如gob.Register(Dog{})。

Golang 的 encoding/gob 包提供了一种高效、原生的对象序列化方式,适用于 Go 程序之间的数据交换。与 JSON 或 XML 不同,gob 是 Go 特有的二进制格式,性能更高,但不具备跨语言兼容性。下面介绍如何在实际项目中使用 gob 进行对象序列化与反序列化。

定义可序列化的结构体

要使用 gob,结构体字段必须是可导出的(即首字母大写),且类型需支持 gob 编码。私有字段或不支持的类型将被忽略。

示例:

type Person struct {
    Name string
    Age  int
    City string
}

该结构体可以直接用于 gob 编码。注意:如果字段前有小写字母(如 name),则不会被序列化。

将对象编码为 gob 并保存到文件

使用 gob.NewEncoder 将对象写入文件或网络流。

  • 打开一个文件用于写入
  • 创建 gob 编码器
  • 调用 Encode 方法写入对象
代码示例:

file, _ := os.Create("person.gob")
defer file.Close()

encoder := gob.NewEncoder(file)
person := Person{Name: "Alice", Age: 30, City: "Beijing"}
err := encoder.Encode(person)
if err != nil {
    log.Fatal("Encode error:", err)
}

从 gob 文件恢复对象

使用 gob.NewDecoder 从文件读取并恢复原始对象。

  • 打开之前保存的 gob 文件
  • 创建解码器
  • 调用 Decode 方法填充目标变量
代码示例:

file, _ := os.Open("person.gob")
defer file.Close()

var person Person
decoder := gob.NewDecoder(file)
err := decoder.Decode(&person)
if err != nil {
    log.Fatal("Decode error:", err)
}
fmt.Printf("Recovered: %+v\n", person)

注册自定义类型(如有指针或接口)

如果结构体包含接口类型或使用了指针指向实现了接口的类型,需要提前调用 gob.Register 注册具体类型。

例如:

type Animal interface {
    Speak() string
}

type Dog struct{}

func (d Dog) Speak() string { return "Woof" }

// 序列化包含接口的结构
type Owner struct {
    Pet Animal
}

// 必须注册具体类型
gob.Register(Dog{})

否则在编解码时会报错:类型未注册。

基本上就这些。gob 使用简单,适合服务内部通信或持久化存储。只要注意字段导出、类型注册和错误处理,就能稳定使用。不复杂但容易忽略细节。