protoc 编译工具
在进行开发 protoc 之前,你需要首先在你的计算机中安装 protoc 编译工具。
下载编译工具
进入 Protocol Buffers 的源代码中然后选择发布的版本中,找到对应的版本。项目的链接地址为:https://github.com/protocolbuffers/protobuf/releases
然后选择 https://github.com/protocolbuffers/protobuf/releases/download/v3.9.0/protoc-3.9.0-win64.zip,对应的版本进行下载。
请注意,如果你这里下载了 3.9.0 的版本的,那么在项目的 Gradle 文件也需要对应的 3.9.0 版本。
请下载对应的版本。
设置环境变量
在下载程序后,需要将下载 zip 文件中的 bin 目录设置到环境变量中。
然后运行 protoc --version 来确定你的编译运行版本已经被正确配置。
通过下图,可以查看配置的文件夹。
通过运行 protoc --version 来确定已经配置正确和编译器版本。
转换 Java 对象
假设我们有一个 proto 文件命名为:simple.proto
simple.proto 的代码在 https://github.com/cwiki-us-demo/protocol-buffers-demo-java/blob/master/src/main/proto/simple.proto 页面中可以访问到。
你可以 Clone 项目到本地后进行执行。
你可以通过运行下面的命令来将 simple.proto 文件为基础生成一个 Java 对象
protoc --proto_path=src --java_out=src/main/java src/main/proto/simple.proto
生成结果如果正常的话,应该是没有输出的。
然后你访问特定的文件夹后就可以看到生成的 Java 对象。
生成的文件的路径和文件在 com.insight.demo.protocolbuffers.mode 这个包中。
请注意,你不能对手动对这个文件进行编译,这个文件都应该是通过程序自动生成的。
GitHub 示例源代码
本教程中的所有源代码都可以在 GitHub 中的 https://github.com/cwiki-us-demo/protocol-buffers-demo-java 项目访问到。
你可以 Clone 代码到你本地后进行运行测试。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
多个module实体类集合打一个jar包并上传至远程库
本章内容主要分享多个module中的实体类集合生成到一个jar包中,并且发布到远程库;这里采用maven-assembly-plugin插件的功能来操作打包,内容不长却贴近实战切值得拥有,主要节点内容如: 多个module实体类集合打jar包 jar包打入本地库 jar包上传至远程库 多个module实体类集合打jar包 首先假设下我们拥有多个module,每个module中有一些接口或公用方法的参数实体和响应实体,再或者有公用枚举,此时为了合作方对接方便,我们需要吧这些个实体类、枚举、接口等集合到一个jar包中,提供给合作方使用; 这里我们可以在项目工程下再创建一个空的module,里面不用包含任何代码,但是需要在pom中加入assmebly插件如: <plugins> <plugin
- 下一篇
Protocol Buffers 简介
本文档的Protocol Buffer 的中文文档使用的是 Asciidoctor 进行编排的 http://docs.ossez.com/protocol-buffers-docs/index.html(本 WIKI 中的内容将会与在线发布的版本同步) Google Protocol Buffer(简称Protobuf)是Google公司内部的混合语言数据标准,目前已经正在使用的有超过48,162种报文格式定义和超过12,183个.proto文件。 如果你在互联网上搜索的话,你可能会看到下面的说明文字。 Google Protocol Buffer(简称Protobuf)是Google公司内部的混合语言数据标准,目前已经正在使用的有超过48,162种报文格式定义和超过12,183个.proto文件。 他们用于RPC系统和持续数据存储系统。 Protocol Buffers是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。 它很适合做数据存储或RPC数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。 目前提供了C++...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装