go使用protobuf

本文介绍了如何在Go中使用protobuf进行对象序列化。详细步骤包括安装Go和protobuf,protobuf的作用及其与encoding/binary的区别。讲解了protobuf的语法、消息类型和数据类型,并指导如何编写.proto文件,通过protoc编译生成.go文件,最后展示了在Go程序中如何使用生成的.pb.go文件进行序列化和反序列化操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先安装go:就不说了,随意百度即可,或者参考我的,https://blog.youkuaiyun.com/u013755520/article/details/89031598末尾有安装go的方式;

安装protobuf 和go的调用接口,参考我的:https://blog.youkuaiyun.com/u013755520/article/details/91375830 ;

protobuf作用,序列化对象,把[]byte 变成:obj {各种属性类型};这个对象里可以有任意类型;

类比:https://blog.youkuaiyun.com/u013755520/article/details/90546726   binary包,把[]byte 变成{uint32 uint32 []byte }对象,这个对象内只有基本类型;

protobuf和bianry包都属于encoding的范畴。


1.protobuf语法

1.1 消息类型

 

1.2 数据类型

 

2.使用protobuf

2.1 按照语法在一个目录比如 proto/ 下编写xx.proto文件

syntax = "proto3";
package pb;

message Person {
    string name = 1;
    int32 age = 2;
    repeated string emails = 3;
    repeated string phones = 4;
}

message PhoneNumber {
    string number = 1;
    PhoneType type = 2;
}
enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
}

2.2  编译:cd 到proto/目录下面,执行以下命令

protoc --go_out=./   *.proto

就会在当前目录下,根据当前目录的xx.proto文件,生成xx.pd.go文件;这个文件里的每一个go结构体,都实现了proto.Message接口,可是我不知道为啥在goland里却没有提示???待研究

2.3 在程序中使用xx.pb.go文件

也就是说,直接在程序中,为pb.go中的结构体开辟好空间,通过proto.Marshal就可以直接把[]byte 转成pb.go的obj了;

反之,直接在程序中就可以通过 proto.Unmashal 就可以把pb.go的obj转化成[]byte了

package main

import (
	"fmt"
	"github.com/micro/protobuf/proto"
	pb "rpc/proto"
)

func main(){
	person := &pb.Person{
		Name:"yz",
		Age:11,
		Emails:[]string{"782365461@qq.com","123456@163.com"},
		Phones:[]*pb.PhoneNumber{
			&pb.PhoneNumber{
				Number:"123456",
				Type:pb.PhoneType_HOME,
			},
			&pb.PhoneNumber{
				Number:"123456",
				Type:pb.PhoneType_MOBILE,
			},
			&pb.PhoneNumber{
				Number:"123456",
				Type:pb.PhoneType_WORK,
			},
		},
	}

	//marshal:  obj---[]byte
	data,err := proto.Marshal(person)
	if err != nil {
		fmt.Println(err)
	}

	//unmarshal : []byte---obj
	newPersonObj := &pb.Person{}
	err = proto.Unmarshal(data,newPersonObj)
	if err != nil {
		fmt.Println(err)
	}

	fmt.Println(newPersonObj)
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值