博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Go语言使用Protobuf举例
阅读量:4207 次
发布时间:2019-05-26

本文共 1412 字,大约阅读时间需要 4 分钟。

Golang是内存安全的带垃圾回收的强类型语言,那么必然不鼓励直接拿到一个地址随便进行类型强转的,虽然通过unsafe包也可以做到。并且,Golang的结构体是不能设置单字节对齐的,所以发送一个结构化的msg给另一个进程时一定要做序列化,接收端收到再做对应的反序列化。当然,也可以使用XML/Json来做通信格式,但是它们是字符串,编解码效率更低,而且也得需要库的支持。有没有一个更加简单高效的编解码方式呢?Protobuf就是一个。

) are Google’s language-neutral, platform-neutral, extensible mechanism for serializing structured data. Protobuf是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。

Protobuf 可以像C语言定义结构体一样定义自己的数据结构,可以说是一种DSL语言了,然后使用其代码生成器(Protobuf向各目标语言编译的编译器)生成对应的代码来读写这个数据结构,很方便。

安装文档:

语法说明:
上面谷歌文档访问不了可以看:
这里有一篇比较老的原理介绍:
如何阅读protobuf源码?

Protobuf 大概分成两部分:compiler 和 runtime, compiler 的前端是手写的递归下降 parser , 后端是各个目标语言的代码生成器,前后端通过 descriptor 联系起来,非常清晰,也便于扩展。

Golang使用的protobuf一个小例子:

  1. 新建一个test目录放ptoto文件和自动生成的代码
syntax = "proto3";package test;enum Sex{   Male = 0;   Female = 1;}message Student{   int32 id = 1;   string name = 2;   Sex sex = 3;}
  1. 用protoc命令生成对应go代码
[test]$ protoc --go_out=. testmsg.proto
  1. 使用proto包来编解码
package mainimport (	"awesomeProject/test"	"fmt"	"github.com/golang/protobuf/proto")func main() {
s := &test.Student{
Id: 1, Name: "Mike", Sex: test.Sex_Female, } fmt.Println(s) // id:1 name:"Mike" sex:Female data, _ := proto.Marshal(s) fmt.Println(data) // [8 1 18 4 77 105 107 101 24 1] ss := new(test.Student) err := proto.Unmarshal(data, ss) if err == nil {
fmt.Println(ss) // id:1 name:"Mike" sex:Female }}

Protobuf使用还是十分方便的。

转载地址:http://wdqli.baihongyu.com/

你可能感兴趣的文章
【HTML5/CSS/JS】开发跨平台应用工具的选择(三)
查看>>
【心灵鸡汤】Give it five minutes不要让一个好主意随风而去
查看>>
【React Native】Invariant Violation: Application AwesomeProject has not been registered
查看>>
【ReactNative】真机上无法调试 could not connect to development server
查看>>
【XCode 4.6】常用快捷键 特别是格式化代码ctrl+i
查看>>
【iOS游戏开发】icon那点事 之 实际应用(二)
查看>>
【iOS游戏开发】icon那点事 之 图标设计(三)
查看>>
【IOS游戏开发】之测试发布(Distribution)
查看>>
【IOS游戏开发】之IPA破解原理
查看>>
【一天一道LeetCode】#45. Jump Game II
查看>>
【一天一道LeetCode】#46. Permutations
查看>>
【一天一道LeetCode】#47. Permutations II
查看>>
【一天一道LeetCode】#48. Rotate Image
查看>>
【一天一道LeetCode】#56. Merge Intervals
查看>>
【一天一道LeetCode】#57. Insert Interval
查看>>
【一天一道LeetCode】#58. Length of Last Word
查看>>
【一天一道LeetCode】#59. Spiral Matrix II
查看>>
【一天一道LeetCode】#30. Substring with Concatenation of All Words
查看>>
【一天一道LeetCode】#60. Permutation Sequence.
查看>>
【一天一道LeetCode】#113. Path Sum II
查看>>