Protocol Buffers
プロトコルバッファは、言語に依存せず、プラットフォームに依存しない、構造化データをシリアライズするための拡張可能なメカニズムです。
Protocol Buffers とは?
プロトコルバッファは、Googleが開発した、言語に依存せず、プラットフォームに依存しない、構造化データをシリアライズするための拡張可能なメカニズムです。XMLのようなものですが、より小さく、高速で、シンプルです。データの構造を一度定義すれば、特別に生成されたソースコードを使用して、様々なデータストリームに対して、また様々な言語を使用して、構造化データを簡単に書き込んだり読み込んだりできます。
お好みの言語を選択
プロトコルバッファは、C++、C#、Dart、Go、Java、Kotlin、Objective-C、Python、Rubyで生成されたコードをサポートしています。proto3では、PHPも使用できます。
実装例
edition = "2023";
message Person {
string name = 1;
int32 id = 2;
string email = 3;
}
図1. Protoの定義。
// Java code
Person john = Person.newBuilder()
.setId(1234)
.setName("John Doe")
.setEmail("jdoe@example.com")
.build();
output = new FileOutputStream(args[0]);
john.writeTo(output);
図2. 生成されたクラスを使用してデータを永続化する。
// C++ code
Person john;
fstream input(argv[1],
ios::in | ios::binary);
john.ParseFromIstream(&input);
id = john.id();
name = john.name();
email = john.email();
図3. 生成されたクラスを使用して永続化されたデータをパースする。
始め方
- プロトコルバッファコンパイラをダウンロードしてインストールします。
- 概要を読みます。
- 選択した言語のチュートリアルを試します。