百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

java中使用protobuf在maven项目中写一个示例

liebian365 2025-02-26 12:41 1 浏览 0 评论

protobuf

前两天上课听玄姐说pb, 对于我这个菜鸡来说, 这玩意都没有听说过, 只能先补充一下基础支持了

1. protobut简介

1. protobut介绍

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

protobuf在google中是一个比较核心的基础库,作为分布式运算涉及到大量的不同业务消息的传递,如何高效简洁的表示、操作这些业务消息在google这样的大规模应用中是至关重要的。而protobuf这样的库正好是在效率、数据大小、易用性之间取得了很好的平衡。

官方文档
http://code.google.com/p/protobuf/

2. protobuf的优缺点

Protobuf的优点如下:A、性能好,效率高: 序列化后字节占用空间比XML少3-10倍,序列化的时间效率比XML快20-100倍。B、有代码生成机制: 将对结构化数据的操作封装成一个类,便于使用。C、支持向后和向前兼容: 当客户端和服务器同时使用一块协议的时候, 当客户端在协议中增加一个字节,并不会影响客户端的使用D、支持多种编程语言: Protobuf目前已经支持Java,C++,Python、Go、Ruby等多种语言。

Protobuf的缺点如下:A、二进制格式导致可读性差B、缺乏自描述

2. idea安装protobuf插件

安装插件protobuf Support,之后重启

3. 配置maven依赖


? ? ? 
? ? ? ? ? com.google.protobuf
? ? ? ? ? protobuf-java
? ? ? ? ? 3.4.0
? ? ? 



? ? ? 
? ? ? ? ? 
? ? ? ? ? ? ? kr.motd.maven
? ? ? ? ? ? ? os-maven-plugin
? ? ? ? ? ? ? 1.4.1.Final
? ? ? ? ? 
? ? ? 
? ? ? 
? ? ? ? ? 
? ? ? ? ? ? ? org.xolstice.maven.plugins
? ? ? ? ? ? ? protobuf-maven-plugin
? ? ? ? ? ? ? 0.5.0
? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? ? ? com.google.protobuf:protoc:3.1.0:exe:${os.detected.classifier}
? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? grpc-java
? ? ? ? ? ? ? 
? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? ? ? ? ? compile
? ? ? ? ? ? ? ? ? ? ? ? ? compile-custom
? ? ? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? ? ? 
? ? ? ? ? ? ? 
? ? ? ? ? 
? ? ? 

4. 书写proto文件

syntax?=?"proto3";
option?java_package?=?"com.jihite";
option?java_outer_classname?=?"PersonModel";

message?Person?{
? ??int32?id?=?1;
? ??string?name?=?2;
? ??string?email?=?3;
}

5. 转换成java文件

6. 测试

把生成的类考的代码路径下,用下面测试用例测试

package?com.jihite;

import?com.google.protobuf.InvalidProtocolBufferException;
import?org.junit.Test;
public?class?protobufTest?{
? ?@Test
? ?public?void?testN()?throws?InvalidProtocolBufferException?{
? ? ? ?PersonModel.Person.Builder?builder?=?PersonModel.Person.newBuilder();
? ? ? ?builder.setId(1);
? ? ? ?builder.setName("jihite");
? ? ? ?builder.setEmail("jihite@jihite.com");

? ? ? ?PersonModel.Person?person?=?builder.build();
? ? ? ?System.out.println("before:"?+?person);

? ? ? ?System.out.println("===Person Byte:");
? ? ? ?for?(byte?b?:?person.toByteArray()) {
? ? ? ? ? ?System.out.print(b);
? ? ? }
? ? ? ?System.out.println("================");

? ? ? ?byte[]?byteArray?=?person.toByteArray();
? ? ? ?PersonModel.Person?p2?=?PersonModel.Person.parseFrom(byteArray);
? ? ? ?System.out.println("after id:"?+?p2.getId());
? ? ? ?System.out.println("after name:"?+?p2.getName());
? ? ? ?System.out.println("after email:"?+?p2.getEmail());

? }
}

结果:

before:id:?1
name:?"jihite"
email:?"jihite@jihite.com"

===Person?Byte:
811861061051041051161012617106105104105116101641061051041051161014699111109================
after?id:1
after?name:jihite
after?email:jihite@jihite.com

相关推荐

20 个 2020 年软件开发趋势预测

企业上云已成不可逆的趋势,全面云计算时代宣告来临,微服务已成软件架构主流,Kubernetes将会变得更酷,2020年还有哪些技术趋势值得观察?一起来看!1.基础设施:条条道路通云端对于云厂商来...

目录发布!安徽这些紧缺人才急需

《安徽省5G产业急需紧缺人才目录(2020-2025)》(以下简称目录)近日正式发布。本次调研调查了216家代表企业、6家头部企业,获取了426份有效问卷,分析安徽省5G产业紧缺人才需求现状,其中产品...

AI树莓派——构建树莓派大脑(NCNN环境搭建)

前言镜像已经做好了,传到百度网盘中了(请大家及时保存,不定期删除!)...

把远程进程通讯grpc引入到Spring boot maven项目中

1、参考链接:gRPC官网:https://grpc.io/HTTP2:https://http2.github.io/...

面向数据的架构

在软件架构中,有一种模式虽鲜为人知的,但值得引起更多的关注。面向数据的架构(Data-OrientedArchitecture)由RajiveJoshi在RTI的2007年白皮书中首次提出,...

Go语言11岁了,网友:他喵的,终于确定出「泛型」了

金磊发自凹非寺量子位报道|公众号QbitAI比Python更快,比Java更简洁,还有C++没有的GC...

深度剖析数据库国产化迁移之路

作者|吴夏,腾讯云TDSQL高级工程师责编|唐小引头图|CSDN下载自东方IC出品|CSDN(ID:CSDNnews)随着国家有关部门近年来陆续出台相关政策指导文件,推动探索安...

一文掌握物体检测库TensorFlow 2.x Object Detection安装

...

团队协作-代码格式化工具clang-format

环境:clang-format:10.0.0前言统一的代码规范对于整个团队来说十分重要,通过git/svn在提交前进行统一的ClangFormat格式化,可以有效避免由于人工操作带来的代码格式问题。...

嵌入式大杂烩周记 第 9 期:nanopb

大家好,我是杂烩君。...

开源鸿蒙 OpenHarmony 3.1 Beta 版本发布:系统基础能力增强

IT之家1月2日消息,OpenAtom社区已于12月31日发布了OpenHarmony-v3.1-Beta版本。版本概述当前版本在OpenHarmony3.0LTS的基础...

零基础物联网开发,踩坑无数,得到这份宝典 | 原力计划

作者|Haor.L责编|王晓曼出品|CSDN博客笔者最近参加了校内的一场物联网开发竞赛,从零开始,踩坑无数,感觉很多时候事情都不像预料的一样发展,离开了美好的IDE,太多事情要在板子上一步...

gRPC:Google开源的基于HTTP/2和ProtoBuf的通用RPC框架

gRPC是一个高性能、通用的开源RPC框架,其由Google主要面向移动应用开发并基于HTTP/2协议标准而设计,基于ProtoBuf(ProtocolBuffers)序列化协议开发,且支持众多开发...

搜狗开源srpc:自研高性能通用RPC框架

今年7月底,搜狗公司开源了内部的工业级C++服务器引擎Workflow,一路收获业内许多认可和关注。9月15日,作为Workflow最重要的生态项目——srpc,一个基于其打造的轻量级RPC框架,也在...

WebSocket与Protobuf在现代网络通信中的应用实践

在现代网络通信中,WebSocket和Protobuf已成为构建高效、跨平台通信系统的关键技术。本文将详细介绍如何使用这两种技术来实现一个稳定且高效的网络通信系统。...

取消回复欢迎 发表评论: