Golang 序列化之 ProtoBuf

ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以根据 ProtoBuf 的语言规范生成多种编程语言(Golang、Python、Java 等)的接口代码,本篇只讲述 Golang 的基础操作。据说 ProtoBuf 所生成的二进制文件在存储效率上比 XML 高 3~10 倍,并且处理性能高 1~2 个数量级,这也是选择 ProtoBuf 作为序列化方案的一个重要因素之一。

安装

1.安装 protoc :Protoc下载地址(https://github.com/google/protobuf/releases),可以根据自己的系统下载相应的 protoc,windows 用户统一下载 win32 版本。

2.配置 protoc 到系统的环境变量中,执行如下命令查看是否安装成功:

$ protoc --version
# 如果正常打印 libprotoc 的版本信息就表明 protoc 安装成功

3.安装 ProtoBuf 相关的 golang 依赖库

$ go get -u github.com/golang/protobuf/{protoc-gen-go,proto}

使用

1.创建 Demo golang工程

2.在 example 包中编写 person.proto

 syntax = "proto3";
 package example;

 message person {    //  aa 会生成 Aa 命名的结构体
     int32 id = 1;
     string name = 2;
 }

 message all_person {    //  aa_bb 会生成 AaBb 的驼峰命名的结构体
     repeated person Per = 1;
 }

3.进入 Demo 工程的 example 目录,使用 protoc 编译 person.proto

$ protoc --go_out=. person.proto
# 就会生成 person.pb.go 文件

4.在 golang 工程中使用 protobuf 进行序列化与反序列化

# main.go
 package main

 import (
     "github.com/golang/protobuf/proto"
     "Demo/example"
     "log"
 )

 func main() {
     // 为 AllPerson 填充数据
     p1 := example.Person{
         Id:*proto.Int32(1),
         Name:*proto.String("xieyanke"),
     }

     p2 := example.Person{
         Id:2,
         Name:"gopher",
     }

     all_p := example.AllPerson{
         Per:[]*example.Person{&p1, &p2},
     }

     // 对数据进行序列化
     data, err := proto.Marshal(&all_p)  
     if err != nil {
         log.Fatalln("Mashal data error:", err)
     }

     // 对已经序列化的数据进行反序列化
     var target example.AllPerson
     err = proto.Unmarshal(data, &target)
     if err != nil{
         log.Fatalln("UnMashal data error:", err)
     }

     println(target.Per[0].Name) // 打印第一个 person Name 的值进行反序列化验证
 }

原文发布于微信公众号 - Golang语言社区(Golangweb)

原文发表时间:2017-11-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏张善友的专栏

自动类型安全的.NET标准REST库refit

在SCOTT HANSELMAN 博客上看到一个好东西《Exploring refit, an automatic type-safe REST library...

2087
来自专栏java系列博客

深入理解Java内存模型(一)——基础

1704
来自专栏pangguoming

ElasticSearch客户端注解使用介绍

The best elasticsearch highlevel java rest api-----bboss

1143
来自专栏一个会写诗的程序员的博客

Springboot Application 集成 OSGI 框架开发

是 Java 类加载层次中最顶层的类加载器,负责加载 JDK 中的核心类库,如:rt.jar、resources.jar、charsets.jar 等

1492
来自专栏区块链

GoAHEAD嵌入式WEB SERVER漏洞概览

GOAHEAD由于开源、简单、轻巧、功能强大、多平台等特点,主要运用于嵌入式设备上。考虑到如路由器等等的使用场景等加上出现的漏洞情况等等,使得其漏洞利用难度也会...

2596
来自专栏xingoo, 一个梦想做发明家的程序员

JSP基本语法

  记录一下自己复习到的知识点,以后看起来也方便。   指令   JSP中三个指令,page,include,taglib page 用于定义页面相关的信息,...

27010
来自专栏python3

习题20:函数和文件

readline()函数返回的内容中包含文件本来就有的\n,而print在打印时又会添加一个\n

1023
来自专栏Golang语言社区

Golang 序列化之 ProtoBuf

ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以根据 ProtoBuf 的语言规范生成多种编程...

3715
来自专栏Android相关

Android---SharedPreferences解析

SharedPreferences真正实现的类是:SharedPreferencesImpl

1973
来自专栏Android 研究

Retrofit解析2之使用简介

前面介绍完RESTful之后,我们先来初步认识下Retrofit的使用"姿势"。本文的主要内容如下:

7863

扫码关注云+社区

领取腾讯云代金券