Go最新【杂谈】protobuf详解(1),2024年最新Golang开发者出路在哪

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

在查阅相关资料学习 ProtoBuf 以及研读其源码之后,发现其在效率、兼容性等方面非常出色。在以后的项目技术选型中,尤其是网络通信、通用数据交换等场景应该会优先选择 ProtoBuf。

下面详细的看下protobuf相关的内容

Protobuf简介

protobuf (protocol buffer) 是谷歌内部的混合语言数据标准。通过将结构化的数据进行序列化,用于通讯协议、数据存储等领域和语言无关、平台无关、可扩展的序列化结构数据格式。

官方网站:https://developers.google.cn/protocol-buffers
推荐:https://zhuanlan.zhihu.com/p/141415216

protobuf的几个特点

多语言,多平台。自定义源文件,存储类
高效。二进制数据交互格式,可以安装编译器protoc.proto编译成各种文件 变成可以使用的类
扩展性好,兼容性好。可以在源文件更新数据结构

Protobuf使用

工作流程
在介绍如何使用protobuf之前,我们先看看它的工作流程,
Linux技术宅 出处bilibili
对于序列化协议来说,使用方只需要关注业务对象本身,即 idl 定义,序列化和反序列化的代码只需要通过工具生成即可

创建 .proto文件

定义数据结构,参考官方的实例

syntax = "proto2";

package tutorial;

message Person {
  optional string name = 1;
  optional int32 id = 2;
  optional string email = 3;

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }

  message PhoneNumber {
    optional string number = 1;
    optional PhoneType type = 2 [default = HOME];
  }

  repeated PhoneNumber phones = 4;
}

message AddressBook {
  repeated Person people = 1;
}

这里边涉及到一些protobuf的一些语法规则,其中message是定义一个消息类型的关键字,相当于在一些语言中定义类class。每个message都会生成一个名字与之对应的类,该类公开继承自google::protobuf::Message。具体数据定义的语法规则,我们后面详细展开介绍(proto中2和3有些语法的区别)。

编译proto文件

这里涉及到protoc编译器的下载和安装

下载地址:https://github.com/protocolbuffers/protobuf/releases

# window
https://blog.csdn.net/weixin_43440680/article/details/122178381

# linux
tar -xzf protobuf-2.1.0.tar.gz
cd protobuf-2.1.0
./configure --prefix=$INSTALL_DIR
make
make check
make install

安装完成之后,可以使用protoc命令对.proto文件进行编译,生成对应的文件

protoc -I=$src_dir --python_out=$dst_dir xxx.proto

  • $src_dir 所在的源目录
  • –python_out 生成python代码
  • $dst_dir 生成代码的目录
  • xxx.proto 针对那个proto文件生成接口
class Person(message.Message):
  __metaclass__ = reflection.GeneratedProtocolMessageType

  class PhoneNumber(message.Message):
    __metaclass__ = reflection.GeneratedProtocolMessageType
    DESCRIPTOR = _PERSON_PHONENUMBER
  DESCRIPTOR = _PERSON

class AddressBook(message.Message):
  __metaclass__ = reflection.GeneratedProtocolMessageType
  DESCRIPTOR = _ADDRESSBOOK

编写writer和reader

Writing A Message

#! /usr/bin/python

import addressbook_pb2
import sys

# This function fills in a Person message based on user input.
def PromptForAddress(person):
  person.id = int(raw\_input("Enter person ID number: "))
  person.name = raw\_input("Enter name: ")

  email = raw\_input("Enter email address (blank for none): ")
  if email != "":
    person.email = email

  while True:
    number = raw\_input("Enter a phone number (or leave blank to finish): ")
    if number == "":
      break

    phone_number = person.phones.add()
    phone_number.number = number

    type = raw\_input("Is this a mobile, home, or work phone? ")
    if type == "mobile":
      phone_number.type = addressbook_pb2.Person.PhoneType.MOBILE
    elif type == "home":
      phone_number.type = addressbook_pb2.Person.PhoneType.HOME
    elif type == "work":
      phone_number.type = addressbook_pb2.Person.PhoneType.WORK
    else:
      print "Unknown phone type; leaving as default value."

# Main procedure: Reads the entire address book from a file,
# adds one person based on user input, then writes it back out to the same
# file.
if len(sys.argv) != 2:
  print "Usage:", sys.argv[0], "ADDRESS\_BOOK\_FILE"
  sys.exit(-1)



![img](https://img-blog.csdnimg.cn/img_convert/596d31f7666c0dea39d0faa193608139.png)
![img](https://img-blog.csdnimg.cn/img_convert/da76746d641a4885556448f055224422.png)
![img](https://img-blog.csdnimg.cn/img_convert/1c69dd86715a48bcf8a0e1a9d7ec5d4a.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**

有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**

  • 13
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值