加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

[Go] 使用protobuf进行序列化和反序列化

发布时间:2021-05-21 06:47:09 所属栏目:大数据 来源: https://www.jb51.cc
导读:先定义消息类型 orders.proto @H_502_4@ Syntax = " proto2 " ;package message;message Orders {required int32 order_id = 1 ;required string title= 2 ;} 在GOPATH创建目录和编译这个消息类型输出到该目录,包名是message @H_502_4@ mkdir $GOPATH/src/m

先定义消息类型

orders.proto

@H_502_4@
Syntax = "proto2";
package message;
message Orders {
required int32 order_id=1;
required string title=2;
}

在GOPATH创建目录和编译这个消息类型输出到该目录,包名是message

@H_502_4@
mkdir $GOPATH/src/message;protoc --go_out $GOPATH/src/message orders.proto 

编写go文件进行序列化和反序列化刚才生成的包里的类型结构体数据

@H_502_4@
package main

import message

import github.com/golang/protobuf/protofmt

func main() {
    orders := &message.Orders{
        OrderId: proto.Int32(),Title:   proto.String(第一个订单//序列化成二进制数据
    ordersBytes,_ := proto.Marshal(orders)
    反序列化二进制数据
    twoOrders := &message.Orders{}
    proto.Unmarshal(ordersBytes,twoOrders)
    fmt.Println(twoOrders.GetTitle())
    .Println(twoOrders.GetOrderId())

}

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读