以下全部基于win7系统。

protobuf是什么,有什么用网上说的已经很多了。这里就是说一下怎么使用。就当给自己做个笔记吧。

.proto文件的语法什么的也请网上查看,挺多的。

第一步: 下载protoc.exe 和 protobuf-java-2.4.1.jar。这里要注意版本区别(网上不少人说要下载protoc-2.4.1-win32.zip,但是没有找到)。其实protobuf就不用安装,只是使用protoc.exe生成一下java文件罢了。

下载路径 http://pan.baidu.com/s/1sj0VX1r

也可以下载最新版:https://developers.google.com/protocol-buffers/docs/downloads

第二步:下载好后任意放到一个文件夹,这里我放到了E:/protobuf下。然后新建一个person.proto文件:

option java_package = "com.zh.test";
option java_outer_classname = "Persons";
message PersonInfo {
required int32 id = 1;
required string name = 2;
}

第三步:生成java文件。在cmd中执行命令E:\protobuf>protoc.exe --java_out=./ person.proto。注意:./后面有一个空格

    然后就能看到在当前文件夹下生成一个com文件夹,这就是上面生成的.java文件的包了。逐级打开包就能看到Persons.java文件了。

第四步:把生成的Persons.java文件拷贝的项目中,然后就可以测试了,看如下代码

public class TestProtobuf {
public static void main(String[] args) {
Persons.PersonInfo.Builder builder=Persons.PersonInfo.newBuilder();
builder.setId(1);
builder.setName("zhang");
Persons.PersonInfo info=builder.build();
byte[] result=info.toByteArray();
System.out.println("==========="+result); try {
Persons.PersonInfo msg = Persons.PersonInfo.parseFrom(result);
System.out.println(msg.getId());
System.out.println(msg.getName());
} catch (InvalidProtocolBufferException e) {
e.printStackTrace();
}
} }

OK,到这里就完成了序列化。

protobuf的安装和使用的更多相关文章

  1. PHP7中Protobuf的安装使用

    PHP7中Protobuf的安装使用 写这篇文章的缘由是最近在关注RPC框架序列化的一些原理.但是在安装Protobuf的时候,发现网上的教程都太老了,加上目前Protobuf官方已经支持PHP了,不 ...

  2. Protobuf从安装到配置整理帖

    新做的Mini项目计划使用Google的Protobuf来做,关于Protobuf是什么玩意能干什么请自己去看这里:http://code.google.com/p/protobuf/ 这里讲一下安装 ...

  3. Google protobuf的安装及使用

    最近应为工作的需要,合作的部门提供了protobuf的接口,总结了一下使用的过程和方法如下: 下载protobuf-2.3.0: http://protobuf.googlecode.com/file ...

  4. Protobuf从安装到配置整理帖 --转

    新做的Mini项目计划使用Google的Protobuf来做,关于Protobuf是什么玩意能干什么请自己去看这里:http://code.google.com/p/protobuf/ 这里讲一下安装 ...

  5. protobuf 编译安装

    1.protobuf是google公司提出的数据存储格式,详细介绍可以参考:https://developers.google.com/protocol-buffers 2.下载最新的protobuf ...

  6. Protobuf的安装使用

    date: 2018-10-12  18:59:13 版权归属原作者,本位转自:https://www.cnblogs.com/autyinjing/p/6495103.html 1. 是什么? Go ...

  7. protobuf编译安装

    为什么选择protobuf,而不选择thift和avro,原因大概几点吧,网上对比的文章很多,我主要关注以下几点 1.protobuf序列化性能最好,序列化后字节数最少. 2.protobuf是单纯的 ...

  8. C++ProtoBuf的安装与使用

    目录 安装(Ubuntu 16.04) 简介 proto2 proto3 用法 proto3 输出结果 总结 @(目录) 安装(Ubuntu 16.04) sudo apt-get install a ...

  9. protobuf文档翻译-安装,数据格式及编码规范

    Install Download protobuf: https://github.com/protocolbuffers/protobuf/releases unzip protoc-3.8.0-l ...

随机推荐

  1. WordPress 非插件实现拦截无中文留言

    Some Chinese Please 插件可以拦截不带中文字的留言,之前本博客一直在用效果不错,不写入数据库,可有效地减少 spam 对服务器的无谓使用,其实可以将插件简化一下,直接用代码实现.将下 ...

  2. asp.net 发布后用IP访问正常,用机器名访问布局出错

    问题如题[发布后IP访问正常,用机器名访问布局出现问题] 出现此问题的原因:IE文档模型发生变化,比如ip访问时IE文档模型为:IE10,换用机器名访问时,文档模型变为IE7 解决方法:设置默认IE版 ...

  3. 深入理解Java String#intern() 内存模型

    原文出处: codelog.me 大家知道,Java中string.intern()方法调用会先去字符串常量池中查找相应的字符串,如果字符串不存在,就会在字符串常量池中创建该字符串然后再返回. 字符串 ...

  4. rails devise使用

    gem 'devise'rails g devise:install Userrails g devise Userrails g devise:views

  5. 一步一步实现Linux设备驱动的Helloworld模块

    学了那么多程序语言,总是有一个Hello world开头,不禁感叹Hello world的强大.呵呵,废话少说,咋们的故事当然要从这个Hello world开始. 先查看自己OS使用的内核版本[don ...

  6. Android--获取标题栏,状态栏,屏幕高度

    获取状态栏高度 Rect frame = new Rect(); getWindow().getDecorView().getWindowVisibleDisplayFrame(frame); int ...

  7. EF6 在原有数据库中使用 CodeFirst 总复习(三、重建迁移)

    本来原来学的时候,挺顺利的,没想到再次使用,还是遇到很多问题,导致更新失败,所以,只能重建迁移,免得看着乱乱的. 一.删除迁移,将数据恢复到(一)结束状态 1.删除文件夹 2.删除表 3.删除列 4. ...

  8. SharePoint 2010 RBS 安装和配置的一些记录

    1.SharePoint 2010 RBS FILESTREAM Provider 的“垃圾收集”: 在SharePoint 中删除上传的文档RBS并不会在文件系统删除文档,理解只是在内容数据库删除了 ...

  9. 2.1孙鑫C++

    0.vc++6.0 工程---win32控制台程序            文件---c++ 1.建立结构体 #include <iostream.h> struct Point { int ...

  10. JS全局屏蔽回车事件

    window.onload = function (){ document.body.onkeydown=function(event){ if(event.keyCode==13){ event.k ...