1, 下载compiler和源代码
http://code.google.com/p/protobuf/downloads/
build protobuf:
./configure
make
make check
make install
2, 创建一个addressbook.proto
package tutorial;
message Person {
required string name = 1;
required int32 id = 2;
optional string email = 3;
enum PhoneType {
MOBILE = 0;
HOME = 1;
WORK = 2;
}
message PhoneNumber {
required string number = 1;
optional PhoneType type = 2 [default = HOME];
}
repeated PhoneNumber phone = 4;
}
message AddressBook {
repeated Person person = 1;
}
3, 生成C++的stub
protoc --cpp_out=. ./addressbook.proto
运行上面的命令将生成addressbook.pb.h和addressbook.pb.cc
4, 写
// write.cc
#include <iostream>
#include <fstream>
#include <string>
#include "addressbook.pb.h"
using namespace std;
void PromptForAddress(tutorial::Person* person) {
cout << "Enter person ID number: ";
int id;
cin >> id;
person->set_id(id);
cin.ignore(256, '\n');
cout << "Enter name: ";
getline(cin, *person->mutable_name());
cout << "Enter email address (blank for none): ";
string email;
getline(cin, email);
if (!email.empty()) {
person->set_email(email);
}
while(true) {
cout << "Enter a phone number (or leave blank to finish):";
string number;
getline(cin, number);
if (number.empty()) {
break;
}
tutorial::Person::PhoneNumber *phone_number = person->add_phone();
phone_number->set_number(number);
cout << "Is this a mobile, home, or work phone?";
string type;
getline(cin, type);
if (type == "mobile") {
phone_number->set_type(tutorial::Person::MOBILE);
} else if (type == "home") {
phone_number->set_type(tutorial::Person::HOME);
} else {
cout << "Unknown phone type. Using default." << endl;
}
}
}
int main(int argc, char* argv[]) {
GOOGLE_PROTOBUF_VERIFY_VERSION;
if(argc != 2) {
cerr << "Usage: " << argv[0] << " ADDRESS_BOOK_FILE" << endl;
return -1;
}
tutorial::AddressBook address_book;
{
fstream input(argv[1], ios::in | ios::binary);
if (!input) {
cout << argv[1] << ": File not found. Creating a new file." << endl;
} else if (!address_book.ParseFromIstream(&input)) {
cerr << "Failed to parse address book." << endl;
return -1;
}
}
PromptForAddress(address_book.add_person());
{
fstream output(argv[1], ios::out | ios::trunc | ios::binary);
if (!address_book.SerializeToOstream(&output)) {
cerr << "Failed to write address book." << endl;
return -1;
}
}
google::protobuf::ShutdownProtobufLibrary();
return 0;
}
编译生成write.exe
注意:
需要将protobuf的源码以及lib加到编译的PATH中
向文件写数据:
write ADDRESS_BOOK_FILE
Enter person ID number: 123
Enter name: Hideto
Enter email address (blank for none): hideto.bj@gmail.com
Enter a phone number (or leave blank to finish):159xxxxxxxx
Is this a mobile, home, or work phone?mobile
Enter a phone number (or leave blank to finish):
write ADDRESS_BOOK_FILE
// ....
5, 读
// read.cc
#include <iostream>
#include <fstream>
#include <string>
#include "addressbook.pb.h"
using namespace std;
void ListPeople(const tutorial::AddressBook& address_book) {
for (int i = 0; i < address_book.person_size(); i++) {
const tutorial::Person& person = address_book.person(i);
cout << "Person ID: " << person.id() << endl;
cout << "Name: " << person.name() << endl;
if(person.has_email()) {
cout << "E-mail address: " << person.email() << endl;
}
for (int j = 0; j < person.phone_size(); j++) {
const tutorial::Person::PhoneNumber& phone_number = person.phone(j);
switch (phone_number.type()) {
case tutorial::Person::MOBILE:
cout << "Mobile phone #: ";
break;
case tutorial::Person::HOME:
cout << "Home phone #: ";
break;
case tutorial::Person::WORK:
cout << "Work phone #: ";
break;
}
cout << phone_number.number() << endl;
}
}
}
int main(int argc, char* argv[]) {
GOOGLE_PROTOBUF_VERIFY_VERSION;
if (argc != 2) {
cerr << "Usage: " << argv[0] << "ADDRESS_BOOK_FILE" << endl;
return -1;
}
tutorial::AddressBook address_book;
{
fstream input(argv[1], ios::in | ios::binary);
if (!address_book.ParseFromIstream(&input)) {
cerr << "Failed to parse address book." << endl;
return -1;
}
}
ListPeople(address_book);
google::protobuf::ShutdownProtobufLibrary();
return 0;
}
编译生成read.exe
从文件读数据:
read ADDRESS_BOOK_FILE
// 以下为输出
Person ID: 123
Name: Hideto
E-mail address: hideto.bj@gmail.com
Mobile phone #: 159xxxxxxxx
Person ID: 456
Name: chuang
E-mail address: chuang@freewheel.tv
Home phone #: 22222222
Person ID: 1231231
Name: asdfadsf
E-mail address: fadsfdsf@dasfads.com
Mobile phone #: 12321321321
Home phone #: 123432432
6, Ruby的protobuf库
http://code.google.com/p/ruby-protobuf/
安装:
gem install ruby_protobuf
生成ruby的stub:
rprotoc addressbook.proto
从文件读数据:
# read.rb
require 'addressbook.pb.rb'
def list_people(address_book)
address_book.person.each do | p |
p "Person ID: #{p.id}"
p "Name: #{p.name}"
p "E-mail: #{p.email}" unless p.email.empty?
p.phone.each do |phone|
case phone.type
when Tutorial::Person::PhoneType::MOBILE
print "Mobile phone #: "
when Tutorial::Person::PhoneType::HOME
print "Home phone #: "
when Tutorial::Person::PhoneType::WORK
print "Work phone #: "
end
p phone.number
end
end
end
address_book = Tutorial::AddressBook.new
address_book.parse_from_file ARGV[0]
list_people address_book
运行:
ruby read.rb 'D:\cpp-projects\pb\bin\Release\ADDRESS_BOOK_FILE'
// 输出
"Person ID: 123"
"Name: Hideto"
"E-mail: hideto.bj@gmail.com"
Mobile phone #: "159xxxxxxxx"
"Person ID: 456"
"Name: chuang"
"E-mail: chuang@freewheel.tv"
Home phone #: "22222222"
"Person ID: 1231231"
"Name: asdfadsf"
"E-mail: fadsfdsf@dasfads.com"
Mobile phone #: "12321321321"
Home phone #: "123432432"
分享到:
相关推荐
标题“protobuf示例参考”指的是关于protobuf实际操作的指导,可能包含一系列的实例,展示了如何在不同的编程语言中使用protobuf。下面我们将深入探讨protobuf的核心概念、工作原理及常见应用场景。 1. **protobuf...
**protobuf使用示例** protobuf(Protocol Buffers)是Google开发的一种数据序列化协议,它可以将结构化的数据序列化,可用于数据存储、通信协议等方面。它提供了比XML更小、更快、更简单的方式来让结构化数据进行...
标题中的“protobuf java 工程示例”表明我们将探讨Google的Protocol Buffers(简称protobuf)在Java编程语言中的实际应用。Protocol Buffers是一种高效的数据序列化协议,它允许开发者定义数据结构,然后生成能够在...
Protobuf run demo go run main.go # js -> browser open : 127.0.0.1:51002 # go -> go test -v ./go Protobuf是一种用于序列化结构化数据的灵活,高效,自动化的机制。 能够将结构化数据序列化,可用于数据存储,...
protobuf for unity 在unity中使用protobuf工程示例,数据的序列化和反序列化工程示例
总结来说,Netty HTTP Protobuf示例展示了如何利用这三个强大的工具来构建一个高效、可靠的网络通信系统。通过Netty实现HTTP服务器和客户端,利用Protobuf进行高效的数据序列化和反序列化,可以极大地提升应用程序的...
总结来说,“android netty cli +protobuf示例”展示了如何在Android客户端利用Netty的异步网络通信能力和Protobuf的数据序列化特性,构建一个高效的即时通讯系统。这个示例涵盖了从消息定义到网络通信的全过程,...
8. **示例代码**:示例代码通常会涵盖基本的消息定义、序列化、反序列化,以及如何在服务端和客户端使用protobuf进行通信。 9. **生态和工具**:protobuf有一个丰富的生态系统,包括各种语言的库、IDE插件、代码...
本文将详细介绍如何在Windows 7 64位环境下,利用CMake和Visual Studio 2015对Protobuf进行编译,并安装Visual Studio的protobuf编辑插件,以及编写和测试简单的protobuf示例。 1. **编译环境配置**: - 操作系统...
本示例主要探讨如何在PHP中调用使用protobuf编译的RPC接口。 首先,了解protobuf的基本概念。protobuf是一种语言无关、平台无关的序列化框架,它可以将结构化的数据序列化为二进制流,以便在网络间传输或者存储到...
这通常涉及到编译或运行一个特定的protobuf示例程序,以确保系统上的protobuf库和相关工具能够正常工作。这个压缩包文件“Protocol-Buffer-Test”很可能包含了一个或多个测试用例,比如.proto文件(protobuf的接口...
**一个简单的protobuf示例** 假设我们有一个名为`person.proto`的.proto文件,内容如下: ```protobuf syntax = "proto3"; message Person { string name = 1; int32 id = 2; string email = 3; } ``` 使用...
Eclipse Protobuf是一款由Google开发的数据序列化工具,它允许开发者定义数据结构,然后生成能够轻松在各种数据流中解析和编码这些结构的代码。在本文中,我们将深入探讨如何在Eclipse环境中安装和配置Protobuf,...
描述中提到,这个压缩包包含了一个基于Visual Studio 2019(VS2019)的protobuf示例工程,这个工程可以帮助开发者理解和学习如何在C++项目中使用protobuf。"Install"文件夹则包含了protobuf编译后的库文件(lib)和...
项目“protobuf_android_sample”应该包含了Android Studio工程文件、protobuf定义文件(.proto)、生成的Java源代码以及相关的示例代码,展示了如何在Android应用中实际使用protobuf。开发者可能还提供了一些测试...
Protocol Buffers是Google公司开发的一种数据描述语言,类似于XML能够将结构化数据序列化,可用于数据存储、通信协议等方面。它不依赖于语言和平台并且可扩展性极强。现阶段官方支持C++、JAVA、Python等三种编程语言...
总结起来,这个压缩包提供了一个简单的zeromQ和protobuf结合的C++示例,可以帮助初学者快速理解这两个库的使用方法。通过学习这个示例,你可以掌握如何在C++中创建zeromQ客户端和服务端,以及如何使用protobuf定义...
在本示例中,我们将深入探讨如何利用 Netty 和 Google 的 Protocol Buffers(protobuf)来构建一个简单的服务端和客户端通信系统。 Protocol Buffers 是 Google 提供的一种数据序列化协议,它可以将结构化数据序列...