日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

C++|Java工作笔记-google protobuf基本使用

發(fā)布時間:2025/3/15 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++|Java工作笔记-google protobuf基本使用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

目錄

?

?

前言

protoc生成

Java相關(guān)

C++相關(guān)


?

?

前言

這里主要是生成序列號,在我所做的項(xiàng)目中,一般是把數(shù)據(jù)序列化后扔到消息總線上,消費(fèi)者讀取了,自行解析。

個人感覺這種方式比Json和XML都方便,從數(shù)據(jù)大小來看,也比Json及XML小得多。

本次使用的protoc版本為2.5.0

?

protoc生成

通過編寫proto文件,讓protoc生成對應(yīng)的java或cc,h文件:

如下的proto文件:

message TestProtocStru{required string value1 = 1;required int32 value2 = 2;required bool value3 = 3; }

通過如下命令,生成cc,h以及java

protoc.exe --java_out=./ TestProtocStruMsg.proto protoc.exe --cpp_out=./ TestProtocStruMsg.proto

這里要注意“/”后面是有個空格的。

這里就生成好了,把對應(yīng)的文件拷貝到項(xiàng)目里面即可

?

Java相關(guān)

這里,在安裝Windows版的protobuf就會帶一個jar包,這里我們使用Maven項(xiàng)目,直接從網(wǎng)上加載,也可以手動把這個jar包導(dǎo)入到Maven倉庫中:

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>ProtocDemo</groupId><artifactId>ProtocDemo</artifactId><version>ProtocDemo</version><dependencies><dependency><groupId>com.google.protobuf</groupId><artifactId>protobuf-java</artifactId><version>2.5.0</version></dependency></dependencies></project>

把生成好的文件導(dǎo)入項(xiàng)目中:

Main里面包括Java生成protobuf類,以及解析protobuf類:

package protoc;import protoc.object.TestProtocStruMsg;import java.io.*;public class Main {public static void main(String[] args) throws IOException {TestProtocStruMsg.TestProtocStru.Builder stru = TestProtocStruMsg.TestProtocStru.newBuilder();stru.setValue1("Hello world");stru.setValue2(10086);stru.setValue3(true);TestProtocStruMsg.TestProtocStru struMsg = stru.build();ByteArrayOutputStream outputStream = new ByteArrayOutputStream();struMsg.writeTo(outputStream);//存起來,給C++解析byte[] byteArray = outputStream.toByteArray();File file = new File("file");if(file.exists()){if(!file.delete()){System.out.println("have file, delete failed");return;}}if(!file.createNewFile()){System.out.println("create file failed!");return;}FileWriter fileWriter = new FileWriter(file.getAbsoluteFile(), true);for(int i = 0; i < byteArray.length; i++) {fileWriter.write(byteArray[i]);}fileWriter.close();//存完啦//Java直接解析,C++等會再看ByteArrayInputStream input = new ByteArrayInputStream(byteArray);TestProtocStruMsg.TestProtocStru test = TestProtocStruMsg.TestProtocStru.parseFrom(input);System.out.println("value1: " + test.getValue1());System.out.println("value2: " + test.getValue2());System.out.println("value3: " + test.getValue3());} }

這里會生成一個file文件:

這個文件等會會拿給C++使用。

?

?

C++相關(guān)

這里把protobuf-2.5.0.tar.gz

再根據(jù)官方所說的:

./configure make make check make install

這里在./configure的時候可以指定其路徑:

如果沒有指定,默認(rèn)就會在/usr/local/lib下面。這里搞好后,就可以用了。

這里我建立的是Qt項(xiàng)目:

這里包含,讀取Java剛剛生成的file文件,并且解析,以及使用C++把這個數(shù)據(jù)序列化。

pro文件如下:

QT += core QT -= guiCONFIG += c++11TARGET = probuffDemo CONFIG += console CONFIG -= app_bundleTEMPLATE = appSOURCES += main.cpp \TestProtocStruMsg.pb.ccDEFINES += QT_DEPRECATED_WARNINGSLIBS += -L/usr/local/lib -lprotobuf -lprotobuf-lite -lprotocHEADERS += \TestProtocStruMsg.pb.h

main.cpp如下:

#include <QCoreApplication> #include <QDebug> #include <QFile> #include <QByteArray> #include <iostream> #include <string> #include "TestProtocStruMsg.pb.h"using namespace std;int main(int argc, char *argv[]) {QCoreApplication a(argc, argv);QFile file("/XXX/XXX/XXX/probuffDemo/file");if(!file.open(QIODevice::ReadOnly)){qDebug() << "open failed!";return 0;}QByteArray arr = file.readAll();qDebug() << arr;file.close();TestProtocStru test ;if(!test.ParseFromArray(arr.data(), arr.length())){qDebug() << "parse failed";return 0;}qDebug() << test.value1().c_str();qDebug() << test.value2();qDebug() << test.value3();//create TestProtocStruTestProtocStru *testStru = new TestProtocStru();testStru->set_value1("hehehe");testStru->set_value2(10010);testStru->set_value3(true);string s;if(!testStru->SerializeToString(&s)){qDebug() << "SerializeToString failed!";return 0;}qDebug() << "-------------------------------------------------";TestProtocStru test2 ;if(!test2.ParseFromArray(s.c_str(), s.length())){qDebug() << "parse failed";return 0;}qDebug() << test2.value1().c_str();qDebug() << test2.value2();qDebug() << test2.value3();return a.exec(); }

程序運(yùn)行截圖如下:

?

?

下面給出兩個小程序的下載地址:

C++程序打包:https://github.com/fengfanchen/Qt/tree/master/probuffDemo

Java程序打包:https://github.com/fengfanchen/Java/tree/master/ProtocDemo

總結(jié)

以上是生活随笔為你收集整理的C++|Java工作笔记-google protobuf基本使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。