1 在網站 http://code.google.com/p/protobuf/downloads/list上能夠下載 Protobuf 的源代碼。而後解壓編譯安裝即可以使用它了。
安裝步驟以下所示:
tar -xzf protobuf-2.1.0.tar.gz
cd protobuf-2.1.0
./configure --prefix=/usr/local/protobuf
make
make check
make install
2 > sudo vim /etc/profile
添加
export PATH=$PATH:/usr/local/protobuf/bin/
export PKG_CONFIG_PATH=/usr/local/protobuf/lib/pkgconfig/
保存執行
source /etc/profile
同時 在~/.profile中添加上面兩行代碼,不然會出現登陸用戶找不到protoc命令
3 > 配置動態連接庫路徑
sudo vim /etc/ld.so.conf
插入:
/usr/local/protobuf/lib
4 > su #root 權限
ldconfig
5> 寫消息文件:msg.proto
- package lm;
- message helloworld
- {
- required int32 id = 1;
- required string str = 2;
- optional int32 opt = 3;
- }
將消息文件msg.proto映射成cpp文件
protoc -I=. --cpp_out=. msg.proto
能夠看到生成了
msg.pb.h 和msg.pb.cc
6> 寫序列化消息的進程
write.cc
- #include "msg.pb.h"
- #include <fstream>
- #include <iostream>
- using namespace std;
-
- int main(void)
- {
-
- lm::helloworld msg1;
- msg1.set_id(101);
- msg1.set_str("hello");
- fstream output("./log", ios::out | ios::trunc | ios::binary);
-
- if (!msg1.SerializeToOstream(&output)) {
- cerr << "Failed to write msg." << endl;
- return -1;
- }
- return 0;
- }
編譯 write.cc
g++ msg.pb.cc write.cc -o write `pkg-config --cflags --libs protobuf` -lpthread
執行write
./write, 能夠看到生成了log文件
7> 寫反序列化的進程
reader.cc
- #include "msg.pb.h"
- #include <fstream>
- #include <iostream>
- using namespace std;
-
- void ListMsg(const lm::helloworld & msg) {
- cout << msg.id() << endl;
- cout << msg.str() << endl;
- }
-
- int main(int argc, char* argv[]) {
-
- lm::helloworld msg1;
-
- {
- fstream input("./log", ios::in | ios::binary);
- if (!msg1.ParseFromIstream(&input)) {
- cerr << "Failed to parse address book." << endl;
- return -1;
- }
- }
-
- ListMsg(msg1);
- }
編譯:g++ msg.pb.cc reader.cc -o reader `pkg-config --cflags --libs protobuf` -lpthread
執行./reader 輸出 :
101
hello
8> 寫Makefile文件
- all: write reader
-
- clean:
- rm -f write reader msg.*.cc msg.*.h *.o log
-
- proto_msg:
- protoc --cpp_out=. msg.proto
-
-
- write: msg.pb.cc write.cc
- g++ msg.pb.cc write.cc -o write `pkg-config --cflags --libs protobuf`
-
- reader: msg.pb.cc reader.cc
- g++ msg.pb.cc reader.cc -o reader `pkg-config --cflags --libs protobuf`