windows环境下protobuf的java操作{编译,序列化,反序列化}
google protocol buffer的使用和原理
- 概况:
- Protocol Buffers(也就是protobuf)是谷歌的语言中立的、平台中立的、可扩展的用于序列化结构化的数据;
- windows环境下的安装与使用:
- protocol编译器
- 安装。安装protocol编译器,用来编译.proto文件;
- 下载。路径:https://github.com/google/protobuf/releases。里面有windows版的:protoc-3.6.1.win32.zip。
- 安装。
- 下载完解压后,如果不想安装,可直接在cmd窗口进入解压得到的bin目录操作。
- 安装,把bin目录copy下来,放到操作系统环境变量的path变量后面。
- 使用。
- 自己编写proto文件。例如我这里写的文件:
message demo{
required int32 id = 1;
required string name = 2;
optional string email = 3;
repeated string friends = 4; } - 编译:
- 编译结果挺恶心的,一个只有几行代码的文件,编译结果动不动就是几千行几万行。。。
- 编译命令示例:protoc --protopath D:\lshdownload\protoc-3.6.1-win32\bin --java_out ./ protoDemo.proto
- protoc,编译命令;
- --proto_path,就是你的proto文件所在目录是哪。我这里是D:\lsh_download\protoc-3.6.1-win32\bin。
- --java_out,标识输出的java文件应该放在哪个目录。这里的 ./ 是指当前目录。
- protoDemo.proto,就是我们要编译的文件。
- 自己编写proto文件。例如我这里写的文件:
- 安装。安装protocol编译器,用来编译.proto文件;
- 关于protoc命令参数,大家可以在cmd窗口输入protoc --help 然后回车得到。
- 安装protobuf,这里我选择maven安装。
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>3.6.0</version>
</dependency> - protobuf API的使用:
- java文件,如上.proto文件得到的.java文件,我的文件名是ProtoDemo.java.
- 调用API做什么?
- 序列化;
- 反序列化。
- 编写序列化和反序列化代码如下:
package demo.protobuf; import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; import demo.protobuf.ProtoDemo.demo.Builder; public class SerialAndDesial { public static void main(String[] args) {
Builder b = ProtoDemo.demo.newBuilder();
b.setEmail("dave_peter@foxmail.com");
b.setId(1);
b.setName("lsh"); ProtoDemo.demo protoDemo = b.build(); FileOutputStream output;
try {
//write
output = new FileOutputStream("proto.ser");
protoDemo.writeTo(output);
output.close(); //read
ProtoDemo.demo protoDemo2 = ProtoDemo.demo.parseFrom(new FileInputStream("proto.ser"));
System.out.println(protoDemo2);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} } - 执行结果如下:
aaarticlea/png;base64,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" alt="" />
- protocol编译器
- 参考资料:
windows环境下protobuf的java操作{编译,序列化,反序列化}的更多相关文章
- windows环境下安装pymysql(操作带图)
在windows环境下安装pymysql,首先要找到python的安装位置,如果在c盘,启动cmd的时候,要获取管理员权限. 具体步骤,一,管理员模式启动cmd.在箭头指定位置,搜索cmd,出现快捷方 ...
- Windows环境下JDK的配置及多版本JDK切换的方法记录
(这里记录了笔者了解的关于JDK环境配置的信息,以及针对系统上存在不同版本JDK时所尝试的解决方案.具体来说,是已安装 JDK 8 后,又安装了 JDK 9 时所遇到的问题和尝试的解决方法.这次记录以 ...
- 代理server的理解(1):Windows环境下的代理server设置
浏览器中的代理server设置 Windows系统接口提供的代理server设置是一个全局的代理server的设置,如图所看到的,这里就不多解释: 各个浏览器在使用代理设置的时候,能够主动地获代替理设 ...
- Windows环境下google protobuf入门
我使用的是最新版本的protobuf(protobuf-2.6.1),编程工具使用VS2010.简单介绍下google protobuf: google protobuf 主要用于通讯,是google ...
- Windows环境下使用VS2005编译OpenSSL
如何Windows环境下,使用VS2005编译OpenSSL,虽然这个问题在Baidu.Google上一堆,但安装中还是遇到些问题,在这里 记录下来希望能帮助大家不要在走弯路.注:我是在WinXP S ...
- Openstack 二次开发之:在windows 环境下编译Openstack-java-sdk
在windows环境下使用maven对openstack-java-sdk进行编译 编译源文件 下载源代码 git clonehttps://github.com/woorea/openstack-j ...
- 编译实战 | 手摸手教你在Windows环境下运行Redis6.x
原创:微信公众号 码农参上,欢迎分享,转载请保留出处. 哈喽大家好啊,我是没事就愿意瞎捣鼓的Hydra. 不知道有没有小伙伴像我一样,平常开发中用的是windows操作系统,有时候想装点什么软件,一看 ...
- Windows环境下启动Redis报错:Could not create server TCP listening socket 127.0.0.1:6379: bind: 操作成功完成。(已解决)
问题描述: 今天在windows环境下启动Redis时启动失败报错: 解决方案: ①运行命令:redis-cli.exe ②退出Redis ③运行命令:redis-server.exe redis.w ...
- 第一部分:使用iReport制作报表的详细过程(Windows环境下)
提示:在有些板块,文中的图片看不到,建议到我的blog浏览文章:http://blog.csdn.net/jemlee2002/文章将会涉及3个方面的内容: 第一部分:使用iReport制作报表的详细 ...
随机推荐
- C#多线程编程のSemaphore(信号量,负责协调各个线程)
Semaphore负责协调线程,可以限制对某一资源访问的线程数量 这里对SemaphoreSlim类的用法做一个简单的例子: namespace WpfApplication6 { /// <s ...
- UVA10817-Headmaster's Headache(动态规划基础)
Problem UVA10817-Headmaster's Headache Time Limit: 4500 mSec Problem Description Input The input con ...
- [国家集训队]happiness
嘟嘟嘟 就这么建. --- #include<cstdio> #include<iostream> #include<cmath> #include<algo ...
- 【vue】vue +element 搭建项目,加(解)密
1.安装依赖 cnpm(npm) install --save js-base64 2.应用 import { Base64 } from 'js-base64'; //加密 getEncode(){ ...
- Python 的全局变量
结论: Python 的全局变量只在本文件中生效. 定义全局变量的文件 G.py # define some global variable A = 1 B = 2 C = 3 def fuck(a= ...
- svn离线安装以及配置,管理python自动化脚本
1.使用源码安装,自己make和install,难度还挺大的,改用对应iso中的rpm安装包来安装 2.iso中的rpm包安装,会存在rpm包之间的依赖的关系 3.这种依赖关系,可以处理,仍然在iso ...
- python:利用xlrd模块操作excel
在自动化测试过程中,对测试数据的管理和维护是一个不可忽视的点.一般来说,如果测试用例数据不是太多的话,使用excel管理测试数据是个相对来说不错的选择. 这篇博客,介绍下如何利用python的xlrd ...
- java 在实例化异常的时候做的事情
new Exception 这段代码,会调用父类ThrowAble的构建方法,在构造方法中会调用fillInstackTrace这个native方法. 会把当前线程异常发生的信息,上下文记录在栈调用指 ...
- [LOJ#517]. 「LibreOJ β Round #2」计算几何瞎暴力[trie]
题意 题目链接 分析 记操作异或和为 \(tx\) ,最后一次排序时的异或和为 \(ax\) ,每个数插入时的 \(tx\) 记为 \(b\). 我们发现,一旦数列排序,就会变得容易操作. 对于新加入 ...
- 快看Sample代码,速学Swift语言(3)-运算符
运算符是用来检查,更改或组合值的特殊符号或短语.Swift提供的很多常规的运算符,如+.-.*./.%.=.==等,以及逻辑运算的&&.||等等,基本上不需要重复介绍,我们在这里只需要 ...