[Go] 使用protobuf进行序列化和反序列化
程序员文章站
2023-10-29 08:30:46
先定义消息类型 orders.proto 在GOPATH创建目录和编译这个消息类型输出到该目录,包名是message 编写go文件进行序列化和反序列化刚才生成的包里的类型结构体数据 ......
先定义消息类型
orders.proto
syntax = "proto2"; package message; message orders { required int32 order_id=1; required string title=2; }
在gopath创建目录和编译这个消息类型输出到该目录,包名是message
mkdir $gopath/src/message;protoc --go_out $gopath/src/message orders.proto
编写go文件进行序列化和反序列化刚才生成的包里的类型结构体数据
package main import "message" import "github.com/golang/protobuf/proto" import "fmt" func main() { orders := &message.orders{ orderid: proto.int32(1), title: proto.string("第一个订单"), } //序列化成二进制数据 ordersbytes, _ := proto.marshal(orders) //反序列化二进制数据 twoorders := &message.orders{} proto.unmarshal(ordersbytes, twoorders) fmt.println(twoorders.gettitle()) fmt.println(twoorders.getorderid()) }
推荐阅读
-
[Go] 使用protobuf进行序列化和反序列化
-
C#使用Json.Net进行序列化和反序列化及定制化
-
在C#中使用Json.Net进行序列化和反序列化及定制化
-
Python使用protobuf序列化和反序列化的实现
-
使用JSON JavaScriptSerializer进行反序列化和序列化时报错,字符的长度超出了MaxJsonLength的长度
-
[Go] 使用protobuf进行序列化和反序列化
-
C#使用Json.Net进行序列化和反序列化及定制化
-
在C#中使用Json.Net进行序列化和反序列化及定制化
-
Python使用protobuf序列化和反序列化的实现
-
使用JSON JavaScriptSerializer进行反序列化和序列化时报错,字符的长度超出了MaxJsonLength的长度