《精通并发与Netty》学习笔记(04 - Google Protobuf介绍)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了《精通并发与Netty》学习笔记(04 - Google Protobuf介绍),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2698字,纯文字阅读大概需要4分钟。
内容图文
一 、Google Protobuf 介绍
protobuf是google团队开发的用于高效存储和读取结构化数据的工具,是Google的编解码技术,在业界十分流行,通过代码生成工具可以生成不同语言版本的源代码。protobuf有2.0版本和3.0版本,3.0版本十grpc框架的基础
Protocol buffers目前支持Java, Python, Objective-C, 和C++生成代码。新的proto3语言版本,你可以使用Go, JavaNano, Ruby, 和 C#。
1.为什么使用Protocol buffers
2.下载Protobuf
访问Google的Protobuf项目页需要×××,但是其也把代码放到了Github上,并且提供了不需要编译即可进行使用的版本,地址如下:
https://github.com/protocolbuffers/protobuf/releases 这里我们下载:protoc-3.7.1-win64.zip
二、使用Protobuf编写一个编码解码的最简单程序
在这里我们分三步完成测试:
- 在 .proto结尾的文件中定义消息格式。
- 使用protocol buffers编译器将 .proto结尾的文件生成对应语言的源代码(本demo使用java编译器)。
- 使用Java protocol buffer API 去读写消息。
1.第一步:定义一个Person.proto文件
syntax = "proto2";
package protobuf;
option java_package = "com.ssy.protobuf";
option java_outer_classname = "PersonProbuf";
message Person {
required int32 id = 1;
required string name = 2;
optional int32 age = 3;
optional string address = 4;
}
第二步:使用protocol buffers编译器将对应的.proto文件编译成对应的类
使用文件protoc.exe,cmd命令行运行:
protoc.exe --java_out=E:\Java PersonMsg.proto
第三步:在idea中新建java项目,将上步生成文件拷贝到项目中
第四步:修改 build.gradle 引入proto库 "com.google.protobuf:protobuf-java:3.8.0-rc-1"
一般来说,序列化和反序列化是分开的。例如网络传输,由一方将数据序列化后发送给另一方来接收并解析,序列化发送和接收反序列化并不在一起。但是下面为了例子简单将二者写在同一程序中。
第五步:编写测试程序:
package com.ssy.netty.proto; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.List; public class Test { public static void main(String[] args) throws IOException { // 按照定义的数据结构,创建一个Person PersonProbuf.Person.Builder personBuilder = PersonProbuf.Person.newBuilder(); personBuilder.setId(1); personBuilder.setName("灿灿"); personBuilder.setAge(35); personBuilder.setAddress("河北石家庄"); PersonProbuf.Person xxg = personBuilder.build(); // 将数据写到输出流,如网络输出流,这里就用ByteArrayOutputStream来代替 ByteArrayOutputStream output = new ByteArrayOutputStream(); xxg.writeTo(output); // -------------- 分割线:上面是发送方,将数据序列化后发送 ---------------byte[] byteArray = output.toByteArray(); // -------------- 分割线:下面是接收方,将数据接收后反序列化 --------------- // 接收到流并读取,如网络输入流,这里用ByteArrayInputStream来代替 ByteArrayInputStream input = new ByteArrayInputStream(byteArray); // 反序列化 PersonProbuf.Person xxg2 = PersonProbuf.Person.parseFrom(input); System.out.println("ID:" + xxg2.getId()); System.out.println("name:" + xxg2.getName()); System.out.println("age:" + xxg2.getAge()); System.out.println("address:" + xxg2.getAddress()); } }
运行程序得到结果如图:
到此我们编写了一个简单的基于google Protobuf 协议的测试程序,下节我们会将google Protobuf与netty结合使用,敬请期待!!!
原文:https://www.cnblogs.com/happy2010/p/10885531.html
内容总结
以上是互联网集市为您收集整理的《精通并发与Netty》学习笔记(04 - Google Protobuf介绍)全部内容,希望文章能够帮你解决《精通并发与Netty》学习笔记(04 - Google Protobuf介绍)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。