[解決済み] Google Protobufを使ったMap構造の実装方法
質問
現在、Google protobufを使用していますが、Map構造を利用したいと考えています。しかし、そのようなデータ構造はGoogle protobufに実装されていないことがわかりました。
私の問題は非常に単純です。私は「ページ番号(uint32_t)」と非常にシンプルなコンテンツを持つ構造体を持っています。私が欲しいのは、このページ番号をキーとして使用し、コンテンツを値として使用することです。これなら、スペースとスピードの両方の要求を満たせるはずだ。しかし、Protobufにはそのようなデータ構造はありません。
私が使っている方法は、このようなものです。
message MyPageContent {
required uint32 contentA = 1;
required uint32 contentB = 2;
}
message MyTable {
repeated MyPageContent table= 1;
}
総ページ数はわかっている。そこで、プログラムの最初に、すべてのページコンテンツをテーブルに追加し、特別な値(この値は、ページが存在しないことを通知し、誰もそのコンテンツを使用しないようにするために使用されます。)を追加しました。このようにして、私は暗黙のうちにページ番号をインデックスに使用することができる。ページの準備ができたら、テーブルの中の対応する値を変更する。人々は、コンテンツにアクセスするために、ページ番号をインデックスとして直接使用します。この方法は、多くのスペースを使いますが(多くのページはまだ準備ができていないので、それを知らせるために特別な値をそこに置くだけです。)、アクセスにかかる時間は速いのです。
このようなことを行うための代替方法です。
message MyTable {
repeated uint32 pageNum = 1;
repeated MyPageContent myContent = 2;
}
こうすることで、テーブルの準備ができたときにページを追加することができるんだ。このようにして、テーブルの大きさを制限することができるはずです。しかし、人々はまず、そのページがテーブルの中にあるかどうかを探すために線形検索をしなければならない。これでは、多くの時間を消費してしまいます。
基本的にこれが、私がprotobufでMap構造を使いたい理由です。スペースと時間の両方を節約することができます。
どのように解決するのですか?
まさか、(中略)幸いなことに。
Protobufはデータを操作するためのライブラリではなく、シリアライズするためのライブラリです。だから、データを操作するのは
std::map
などのコンテナを使ってシリアライズし、それを
repeated
のフィールドをprotobufに格納する。
関連
-
[解決済み】C++でint型に無限大を設定する
-
[解決済み】非静的メンバ関数への参照を呼び出す必要がある
-
[解決済み】ファイルから整数を読み込んで配列に格納する C++ 【クローズド
-
[解決済み】エラー:free(): 次のサイズが無効です(fast)。
-
[解決済み】CMakeエラー at CMakeLists.txt:30 (project)。CMAKE_C_COMPILER が見つかりませんでした。
-
[解決済み】標準ライブラリにstd::endlに相当するタブはあるか?
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み] 警告:暗黙の定数変換でのオーバーフロー
-
[解決済み] JavaでMapをListに変換する方法は?
-
[解決済み】画像処理。コカ・コーラ缶」認識のためのアルゴリズム改良
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】C++ - 解放されるポインタが割り当てられていないエラー
-
[解決済み】致命的なエラー LNK1169: ゲームプログラミングで1つ以上の多重定義されたシンボルが発見された
-
[解決済み】文字列関数で'char const*'のインスタンスを投げた後に呼び出されるterminate [閉店].
-
[解決済み】C++の変数はイニシャライザーを持っているが、不完全な型?
-
[解決済み] 非常に基本的なC++プログラムの問題 - バイナリ式への無効なオペランド
-
[解決済み】エラー。switchステートメントでcaseラベルにジャンプする
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み】なぜ、サイズ8の初期化されていない値を使用するのでしょうか?
-
[解決済み】警告 - 符号付き整数式と符号なし整数式の比較
-
[解決済み] 変数サイズのオブジェクトが初期化されないことがある c++