`

Protocol Buffer入门——轻松搭建java环境

    博客分类:
  • Java
 
阅读更多

Protocol Buffer入门——轻松搭建java环境


protobuf介绍 


按照官网的描述:protobuf是google提供的一个开源序列化框架。主要应用于通信协议,数据存储中的结构化数据的序列化。它类 似于XML,JSON这样的数据表示语言,其最大的特点是基于二进制,因此比传统的XML表示高效短小得多。虽然是二进制数据格式,但并没有因此变得复 杂,开发人员通过按照一定的语法定义结构化的消息格式,然后送给命令行工具,工具将自动生成相关的类,可以支持java、c++、python等语言环 境。通过将这些类包含在项目中,可以很轻松的调用相关方法来完成业务消息的序列化与反序列化工作。



protobuf的优势


1、语言中立

2、平台中立

3、高效性


protobuf入门(eclipse下java环境的搭建)


      更多案例请查阅源代码包protobuf-2.3.0.zip 里面有关于各种支持语言(java,C++,python等)的案例。

1、下载jar包 protobuf-java-2.3.0.jar

2、下载编译器protoc.exe

3、新建java工程test_protobuf

4、导入protobuf-java-2.3.0.jar包

5、导入编译器protoc.exe到项目下

6、在项目下建存放文件.proto的文件夹proto

  7、编写message并放在proto文件夹下,有关编写规范和说明请参考官网文档,在这里我引用官网的例子,创建addressbook.proto代码如下:

  1. package tutorial;  
  2. option java_package = "com.example.tutorial";  
  3. option java_outer_classname = "AddressBookProtos";  
  4. message Person {  
  5.   required string name = 1;  
  6.   required int32 id = 2;        // Unique ID number for this person.  
  7.   optional string email = 3;  
  8.   enum PhoneType {  
  9.     MOBILE = 0;  
  10.     HOME = 1;  
  11.     WORK = 2;  
  12.   }  
  13.   message PhoneNumber {  
  14.     required string number = 1;  
  15.     optional PhoneType type = 2 [default = HOME];  
  16.   }  
  17.   repeated PhoneNumber phone = 4;  
  18. }  
  19. // Our address book file is just one of these.  
  20. message AddressBook {  
  21.   repeated Person person = 1;  
  22. }  

 

8、编译addressbook.proto成指定的java类

    命令行下进入编译器所在目录,执行如下命令

     protoc -I=proto/ --java_out=src proto/addressbook.proto

     其中,src为生成的java类的目标位置,这里我们选择项目的默认包,proto/addressbook.proto表示我们的proto文件,运行 后即生成java类,生成的java类被放在了package com.example.tutorial中。刚才我们指定的目标位置是src,为什么现在却被放在了这个包中呢?这和我们的 addressbook.proto文件中的option java_package = "com.example.tutorial";有关。欲了解更多,参考上节提到的官方文档。

9、现在有了生成的AddressBookProtos.java类,我们可以向文件里写入消息了,首先编写AddPerson.java,代码如下:

 

  1. import com.example.tutorial.AddressBookProtos.AddressBook;  
  2. import com.example.tutorial.AddressBookProtos.Person;   
  3. import java.io.BufferedReader;  
  4. import java.io.FileInputStream;  
  5. import java.io.FileNotFoundException;  
  6. import java.io.FileOutputStream;   
  7. import java.io.InputStreamReader;    
  8. import java.io.IOException;    
  9. import java.io.PrintStream;      
  10. class AddPerson{      
  11.     // This function fills in a Person message based on user input.      
  12.     static Person PromptForAddress(BufferedReader stdin,PrintStream stdout)throws IOException{        
  13.         Person.Builder person = Person.newBuilder();  
  14.         stdout.print("Enter person ID: ");        
  15.         person.setId(Integer.valueOf(stdin.readLine()));          
  16.         stdout.print("Enter name: ");        
  17.         person.setName(stdin.readLine());          
  18.         stdout.print("Enter email address (blank for none): ");        
  19.         String email = stdin.readLine();        
  20.         if (email.length() > 0){          
  21.             person.setEmail(email);       
  22.         }         
  23.         while (true){          
  24.             stdout.print("Enter a phone number (or leave blank to finish): ");  
  25.             String number = stdin.readLine();          
  26.             if (number.length() == 0){            
  27.                 break;          
  28.             }            
  29.             Person.PhoneNumber.Builder phoneNumber = Person.PhoneNumber.newBuilder().setNumber(number);  
  30.             stdout.print("Is this a mobile, home, or work phone? ");          
  31.             String type = stdin.readLine();          
  32.             if (type.equals("mobile")){            
  33.                 phoneNumber.setType(Person.PhoneType.MOBILE);      
  34.             } else if (type.equals("home")) {            
  35.                 phoneNumber.setType(Person.PhoneType.HOME);          
  36.             } else if (type.equals("work")) {           
  37.                 phoneNumber.setType(Person.PhoneType.WORK);          
  38.             } else {            
  39.                 stdout.println("Unknown phone type.  Using default.");          
  40.             }            
  41.             person.addPhone(phoneNumber);        
  42.         }          
  43.         return person.build();      
  44.     }        
  45.     // Main function: Reads the entire address book from a file,  adds one person based on user input,   
  46.     //then writes it back out to the same file.      
  47.     public static void main(String[] args) throws Exception{        
  48.         if (args.length != 1) {          
  49.             System.err.println("Usage:  AddPerson ADDRESS_BOOK_FILE");          
  50.             System.exit(-1);        
  51.         }          
  52.         AddressBook.Builder addressBook = AddressBook.newBuilder();          
  53.         // Read the existing address book.        
  54.         try {          
  55.             addressBook.mergeFrom(new FileInputStream(args[0]));        
  56.         } catch (FileNotFoundException e) {          
  57.             System.out.println(args[0] + ": File not found.  Creating a new file.");        
  58.         }          
  59.         // Add an address.        
  60.         addressBook.addPerson(          
  61.             PromptForAddress(new BufferedReader(new InputStreamReader(System.in)), System.out));          
  62.         // Write the new address book back to disk.        
  63.         FileOutputStream output = new FileOutputStream(args[0]);        
  64.         addressBook.build().writeTo(output);       
  65.         output.close();      
  66.     }   
  67. }  

 

首先配置参数,也就是消息被序列化后存储的文件名,这里,我们就把参数设置成AddressBook.代码中提到,运行时如果文件不存在,将会创建文件并写入;如果存在,就写入。运行程序,按照提示输入消息。然后查看我们的项目路径下,将会产生AddressBook文件

10、上一步是将消息序列化到文件中,这一步将文件中的消息反序列化,类似地,我们创建一个类:ListPeople.java 代码如下:

  1. import com.example.tutorial.AddressBookProtos.AddressBook;  
  2. import com.example.tutorial.AddressBookProtos.Person;  
  3. import java.io.FileInputStream;        
  4.     public class ListPeople {      
  5.         // Iterates though all people in the AddressBook and prints info about them.      
  6.         static void Print(AddressBook addressBook) {        
  7.             for (Person person: addressBook.getPersonList()) {          
  8.                 System.out.println("Person ID: " + person.getId());          
  9.                 System.out.println("  Name: " + person.getName());          
  10.                 if (person.hasEmail()) {            
  11.                     System.out.println("  E-mail address: " + person.getEmail());          
  12.                 }            
  13.                 for (Person.PhoneNumber phoneNumber : person.getPhoneList()) {            
  14.                     switch (phoneNumber.getType()) {              
  15.                         case MOBILE:                
  16.                             System.out.print("  Mobile phone #: ");                
  17.                             break;              
  18.                         case HOME:                
  19.                             System.out.print("  Home phone #: ");                
  20.                             break;              
  21.                         case WORK:                
  22.                             System.out.print("  Work phone #: ");                
  23.                         break;            
  24.                     }            
  25.                     System.out.println(phoneNumber.getNumber());          
  26.                 }        
  27.             }      
  28.         }        
  29.         // Main function:  Reads the entire address book from a file and prints all  the information inside.      
  30.         /** 
  31.          * @param args 
  32.          * @throws Exception 
  33.          */  
  34.         public static void main(String[] args) throws Exception {        
  35.             if (args.length != 1) {          
  36.                 System.err.println("Usage:  ListPeople ADDRESS_BOOK_FILE");          
  37.                 System.exit(-1);        
  38.             }          
  39.             // Read the existing address book.        
  40.             AddressBook addressBook = AddressBook.parseFrom(new FileInputStream(args[0]));  
  41.             Print(addressBook);      
  42.         }    
  43. }  

 

运行程序,将会看到我们输入的消息体被遍历并打印出来了!

通过一个简单的例子,希望能够对大家有所帮助!!

分享到:
评论

相关推荐

    IEC 60364-7-722-2018 低压电气装置.第7-722部分:特殊装置或场所的要求.电动车辆的电源.pdf

    IEC 60364-7-722-2018 低压电气装置.第7-722部分:特殊装置或场所的要求.电动车辆的电源.pdf

    eNSP软件安装及拓扑结构搭建.docx

    、eNSP的安装 1.安装eNSP之前必须先安装以下三个插件: VirtualBox WinPcap Wireshack eNSP作为模拟器主体,需要对应版本的VirtualBox和WinPcap提供虚拟环境,Wireshack用于实验当中测试抓取数据包使用。 安装好这三个插件,只需要点下一步选择好对应的安装位置即可,然后就可以安装eNSP软件了。 eNSP的页面

    vmware虚拟机安装教程

    附件是vmware虚拟机安装教程,文件绿色安全,请大家放心下载,仅供交流学习使用,无任何商业目的!

    大屏网站粒子效果实现方式

    大屏网站粒子效果实现方式

    node-v8.11.3-sunos-x86.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    KingbaseES的jar包

    KingbaseES的jar包

    Python编程基础: 掌握核心概念、语法与技巧,涵盖数据类型、控制结构、函数、模块等,适用于初学者及希望夯实基础的开发者

    "想要快速掌握Python编程的基础知识吗?这个资源是您的最佳选择!它详细介绍了Python编程的基本知识点,包括数据类型、控制结构、函数、模块等内容,让您轻松入门Python编程。 无论您是编程初学者,还是有一定编程基础但希望深入学习Python的开发者,这个资源都适合您。它以通俗易懂的语言,配合实例演示,帮助您更好地理解和掌握Python编程的核心概念和技巧。 这个资源的使用场景非常广泛。您可以在学习Python编程的过程中,将其作为参考资料,随时查阅和巩固知识点。也可以在准备Python面试或考试时,通过这个资源进行复习和提升。此外,如果您是计算机相关专业的学生或教师,这个资源也可以作为教学资料,辅助教学和学习。 这个资源的优势在于它的全面性和实用性。它不仅涵盖了Python编程的基础知识点,还提供了一些实用的编程技巧和经验分享。通过学习这个资源,您将能够更加熟练地使用Python编程,解决实际问题和项目挑战。 如果您还在为找不到好的Python编程学习资源而苦恼,那么这个资源将是您的解决方案。它不仅能够帮助您快速入门Python编程,还能够为您的编程之路提供坚实的支持。还等什么

    聚类分析(108页 PPT).ppt

    聚类分析(108页 PPT)

    径硕科技:B2B企业如何一个人搭建内容营销体系?.pdf

    径硕科技:B2B企业如何一个人搭建内容营销体系?.pdf

    ISO IEC 27001-2022 信息安全、网络安全和隐私保护信息安全管理系统要求.pdf

    ISO IEC 27001-2022 信息安全、网络安全和隐私保护信息安全管理系统要求.pdf

    沿海建模系统 (SMC) 3.0 用户手册

    SMC 3.0 用户手册

    node-v4.4.6-x64.msi

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v8.17.0-linux-ppc64le.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    c语言文件读写操作代码

    C语言文件读写操作是C语言编程中的一个基础且重要的部分,它允许程序与磁盘上的文件进行交互,实现数据的存储和读取。以下是关于C语言文件读写操作代码的500字资源描述: C语言提供了丰富的文件操作函数,如fopen、fclose、fread、fwrite、fscanf、fprintf等,这些函数为开发者提供了灵活的文件读写方式。通过这些函数,开发者可以轻松地打开文件、读取文件内容、写入数据到文件,以及关闭文件。 在C语言中,文件通常被视为字节流,这意味着文件操作是以字节为单位进行的。例如,fread函数可以从文件中读取指定数量的字节,而fwrite函数则可以将数据以字节的形式写入文件。这种操作方式使得C语言文件读写具有高度的灵活性和可移植性。 此外,C语言还支持文本模式和二进制模式两种文件打开方式。在文本模式下,文件操作会考虑平台特定的换行符转换;而在二进制模式下,文件操作则直接按字节进行,不进行任何转换。这使得C语言可以适应不同平台和不同文件类型的需求。 一个典型的C语言文件读写操作代码示例会包括使用fopen函数打开文件、使用fread或fscanf函数读取文件内容、对读取到的

    2022年美赛特等奖论文-2022-2022年E题获奖论文合集.pdf

    大学生,数学建模,美国大学生数学建模竞赛,MCM/ICM,2022年美赛特等奖O奖论文

    node-v9.2.1-linux-arm64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    2024-2030中国HMI PLC一体机市场现状研究分析与发展前景预测报告.docx

    2024-2030中国HMI PLC一体机市场现状研究分析与发展前景预测报告

    研发运营一体化(Dev0ps)能力成熟度模型 第7部分-组织结构.pdf

    研发运营一体化(Dev0ps)能力成熟度模型 第7部分-组织结构

    一篇关于图像和视频去噪技术的研究论文,它介绍了一种基于稀疏3D变换域的协同滤波方法

    "Image and video denoising by sparse 3D transform-domain collaborative filtering" 是一篇关于图像和视频去噪技术的研究论文,它介绍了一种基于稀疏3D变换域的协同滤波方法。这种方法的核心思想是利用图像或视频中的空间和时间冗余信息来去除噪声

    BS EN 1822-2-2009 第2部分:气溶胶生产、测量设备、颗粒物计数统计.pdf

    BS EN 1822-2-2009 第2部分:气溶胶生产、测量设备、颗粒物计数统计.pdf

Global site tag (gtag.js) - Google Analytics