如何在 C++/STL 中表示键值树

How can I represent a key-value-tree in C++ / STL

本文关键字:表示 键值 STL C++      更新时间:2023-10-16

我尝试使用键的多个值选项对键值树的表示进行编码。我试图做的是在程序开始时读取"数据树",然后为程序的每个部分提供所需的数据"分支"。到目前为止,我使用的Libs是OpenCV和Intel TBB。

XML 中的数据示例如下所示:

<key_1> value_1 </key_1>
<key_2> value_2 </key_2>
<!--  -->
<key_3> 
    <subkey_1> value_3 </subkey_1>
    <subkey_2> value_4 value_5 value_6 </subkey_1>
</key_3>
<key_4> value_1 </key_4>

到目前为止,我想出了两个类:

  • 用于保存单个键值对的类,名为键值
  • 一个类键值组
  • ,表示键值的集合,能够保存其他键值组

该守则将是:

class KeyValue {
    std::string mKey;
    std::vector<std::string> mValues;
}
class KeyValueGroup {
    // setters, getters, etc
    std::vector<KeyValue> mKeyValues;
    std::vector<KeyValueGroup> mKeyValueGroups;
    std::string mKey;
}

这些值可以是不同类型的,但我将它们转换为 std::string。我的解决方案有效,但我的直觉告诉我这个解决方案可能很尴尬。那么专业人士将如何解决这个问题呢?

问自己的另一个问题是,我是否应该将两个类都包装在 std::shared_ptr 中以提高速度(平均字符串长度约为 5 个字符)。

您投入了多少精力取决于这些数据对程序的性能关键程度、预期的访问/更新模式等。

对于要求不高的用途...

std::map<std::string, std::string> tree;

。其中map的键是XML指定的键的串联,使用合适的分隔符或分隔符(例如空格,'|'';'...? std::unordered_map是另一种选择。 如有必要,可以编写"Key"类来保存std::string并提供一些方便的函数,例如剥离尾随元素等。

如果我需要更花哨的东西,我会考虑第三方库,例如 boost::graph . 另请参阅此问题/答案,了解C++和树木的背景。

您也可以使用 RapidJSON 文档对象。

这允许您使用键和子项表示 JSON 对象。下面是一个例子:

rapidjson::Document document;
// Initialise the rapid json document to an empty object
document.SetObject();
Document::AllocatorType& allocator = document.GetAllocator();
// Add parent keys
document.AddMember("key_1", "value_1", allocator);
document.AddMember("key_2", "value_2", allocator);
document.AddMember("key_3", "value_3", allocator);
// Add subkeys
document["key_3"].SetObject();
document["key_3"].AddMember("subkey_1", "value_3", allocator);