windows环境下golang使用protobuf

本文介绍了在Windows上使用golang与protobuf进行序列化的方法,包括protobuf的优点、IDE(Goland)的设置、编译器配置以及如何进行测试。通过安装protobuf插件,将protoc编译器添加到系统路径,并提供了示例代码展示如何生成和使用.pb.go文件。
摘要由CSDN通过智能技术生成

Protobuf 介绍

序列化库在网络传输,RPC,数据库访问等环境中经常用到,它的性能的好坏直接影响着整个产品的性能, 所以我们有必要对一些优秀的序列化库进一步的学习与掌握.

protobuf是Google开发的一种数据描述语言,能够将结构化的数据序列化,可用于数据存储,通信协议等方面,官方版本支持 Go, C++, Java, Python,社区版本支持更多语言.

相对于JSON和XML具有以下优点:

  1. 简洁
  2. 体积小:是json的10分之一,xml格式的20分之一,是二进制序列化的10分之一
  3. 速度快:解析速度比XML快20 ~ 100倍
  4. 使用Protobuf的编译器,可以生成更容易在编程中使用的数据访问代码
  5. 更好的兼容性,Protobuf设计的一个原则就是要能够很好的支持向下或向上兼容
  6. protobuf将数据序列化为二进制之后,占用的空间相当小,基本仅保留了数据部分,而xml和json会附带消息结构在数据中;

官方文档

IDE设置

默认情况下IDE goland 是不支持protobuf协议文件类型".proto"的,为了更快高效的编写proto文件中的代码下面我们介绍一款插件让其支持,该插件支持关键字高亮及语法错误提示

1、File->Settings->Plugins->输入protobuf support->install,并重启IDE

在这里插入图片描述
2、file->Settings->Editor->File Types,找到Protobuf,注册支持*.proto
在这里插入图片描述

编译器配置

protobuffer属于跨平台,跨语言的协议,有自己的编译器
protoc是Protobuf编译器
下载最新的压缩包,解压后将其中的protoc.exe程序放到gopath的bin目录中,最好把gopath的bin目录添加到系统环境变量里
下载地址:https://github.com/protocolbuffers/protobuf/releases
在这里插入图片描述
测试:

终端输入`protoc --version` 显示版本即代表安装成功
或
执行 `protoc -h`   正常输出 相关指令 没有报任何error,为安装成功

安装protobuf库文件:

go get github.com/golang/protobuf/proto

安装goprotobuf插件(go版本的 Protobuf 编译器插件):

go get github.com/golang/protobuf/protoc-gen-go

示例

目录结构:
在这里插入图片描述

说明:
protos目录中存放我们自己要写的proto格式文件

syntax = "proto3";

// 新版的proto编译器都要求文件中标注编译后文件的存储位置
// 即生成的.pb.go文件会存放在../pb中,并和该文件名保持一致
// test.proto => test.pb.go
option go_package = "../pb";

message Person {
   
    string Name = 1;
    int32 Age = 2;

}

生成.pb.go

到protos目录下执行

protoc --go_out=. *.proto

pb目录下就存放生成的文件

// Code generated by protoc-gen-go. DO NOT EDIT.
// versions:
// 	protoc-gen-go v1.25.0
// 	protoc        v3.14.0
// source: test.proto

package pb

import (
	proto "github.com/golang/protobuf/proto"
	protoreflect "google.golang.org/protobuf/reflect/protoreflect"
	protoimpl "google.golang.org/protobuf/runtime/protoimpl"
	reflect "reflect"
	sync "sync"
)

const (
	// Verify that this generated code is sufficiently up-to-date.
	_ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion)
	// Verify that runtime/protoimpl is sufficiently up-to-date.
	_ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
)

// This is a compile-time assertion that a sufficiently up-to-date version
// of the legacy proto package is being used.
const _ = proto.ProtoPackageIsVersion4

type Person struct {
   
	state         protoimpl.MessageState
	sizeCache     protoimpl.SizeCache
	unknownFields protoimpl.UnknownFields

	Name string `protobuf:"bytes,1,opt,name=Name,proto3" json:"Name,omitempty"`
	Age  int32  
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值