C++|Java工作笔记-google protobuf基本使用
目錄
?
?
前言
protoc生成
Java相關
C++相關
?
?
前言
這里主要是生成序列號,在我所做的項目中,一般是把數據序列化后扔到消息總線上,消費者讀取了,自行解析。
個人感覺這種方式比Json和XML都方便,從數據大小來看,也比Json及XML小得多。
本次使用的protoc版本為2.5.0
?
protoc生成
通過編寫proto文件,讓protoc生成對應的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這里要注意“/”后面是有個空格的。
這里就生成好了,把對應的文件拷貝到項目里面即可
?
Java相關
這里,在安裝Windows版的protobuf就會帶一個jar包,這里我們使用Maven項目,直接從網上加載,也可以手動把這個jar包導入到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>把生成好的文件導入項目中:
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++相關
這里把protobuf-2.5.0.tar.gz
再根據官方所說的:
./configure make make check make install這里在./configure的時候可以指定其路徑:
如果沒有指定,默認就會在/usr/local/lib下面。這里搞好后,就可以用了。
這里我建立的是Qt項目:
這里包含,讀取Java剛剛生成的file文件,并且解析,以及使用C++把這個數據序列化。
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.hmain.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(); }程序運行截圖如下:
?
?
下面給出兩個小程序的下載地址:
C++程序打包:https://github.com/fengfanchen/Qt/tree/master/probuffDemo
Java程序打包:https://github.com/fengfanchen/Java/tree/master/ProtocDemo
總結
以上是生活随笔為你收集整理的C++|Java工作笔记-google protobuf基本使用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring中使用XML方式导入Spri
- 下一篇: C++设计模式-组合模式