欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

[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进行序列化和反序列化