Go语言的encoding/gob包提供高效的Go专用二进制序列化,适用于Go程序间数据传输。使用时需导入”encoding/gob”和”bytes”,结构体字段须首字母大写才能被编码。序列化通过gob.NewEncoder将对象写入字节流,反序列化用gob.NewDecoder从字节流还原对象。例如Person{Name: “Alice”, Age: 30, City: “Beijing”}可成功编码为字节并解码还原。注意gob不跨语言,类型必须匹配,复杂类型需提前注册,避免编码nil值。在内部服务通信或缓存中,gob是轻量高效的选择。

Go语言中的
encoding/gob
包用于对Go对象进行高效的序列化和反序列化,适合在Go程序之间传输或存储数据。它不同于JSON或XML,gob是Go专用的二进制格式,性能更高,但不具备跨语言兼容性。
基本用法说明
使用
gob
前需导入
"encoding/gob"
和
"bytes"
等基础包。序列化过程将Go结构体写入字节流,反序列化则从字节流还原结构体。注意:结构体字段必须是可导出的(首字母大写),否则不会被编码。
序列化示例
以下代码展示如何将一个结构体对象序列化为字节流:
package main
立即学习“go语言免费学习笔记(深入)”;
import (
“bytes”
“encoding/gob”
“fmt”
)
type Person struct {
Name string
Age int
City string
}
func main() {
person := Person{Name: “Alice”, Age: 30, City: “Beijing”}
var buf bytes.Buffer
encoder := gob.NewEncoder(&buf)
err := encoder.Encode(person)
if err != nil {
fmt.Println(“编码失败:”, err)
return
}
data := buf.Bytes()
fmt.Printf(“序列化结果: %vn”, data)
}
反序列化示例
接下来,将上面生成的字节流还原为原始对象:
var decodedPerson Person
buf := bytes.NewBuffer(data)
decoder := gob.NewDecoder(buf)
err = decoder.Decode(&decodedPerson)
if err != nil {
fmt.Println(“解码失败:”, err)
return
}
fmt.Printf(“反序列化结果: %+vn”, decodedPerson)
输出结果为:
反序列化结果: {Name:Alice Age:30 City:Beijing}
,说明数据成功还原。
注意事项
使用
gob
时需注意以下几点:
只能在Go程序间使用,不适用于与其他语言交互 结构体类型在序列化与反序列化时必须完全匹配 首次编码前应注册复杂自定义类型(使用
gob.Register()
) 不要对未初始化的指针或nil值直接编码,可能导致panic
基本上就这些。对于内部服务通信或缓存场景,gob是一个轻量且高效的选择。
以上就是Golangencoding/gob对象序列化与反序列化示例的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1407301.html
微信扫一扫
支付宝扫一扫