根据这里的boost文档:
http://www.boost.org/doc/libs/1_41_0/doc/html/boost_propertytree/container.html"在一个节点中可能有多个具有相同键值的子节点。然而,这些孩子不一定是顺序的。find返回的迭代器可以引用其中的任何一个,并且不能保证其他同名子节点的相对位置。"
示例XML:
<library>
<book><title>Title_1</title></book>
<book><title>Title_2</title></book>
<book><title>Title_3</title></book>
</library>
示例boost代码:
ptree pt;
pt.push_back(ptree::value_type("book", ptree("title")))
// This finds the first book and cannot iterate to the second one:
ptree::const_iterator it = pt.find("book");
既然知道了这些,你怎么能得到所有的书,并确保你把它们都读了呢?
您必须使用equal_range
函数:
std::pair < ptree::const_assoc_iterator, ptree::const_assoc_iterator> bounds =
pt.equal_range("book");
for (ptree::const_assoc_iterator it = bounds.first; it != bounds.second ; ++it)
{
// process *it
}