6

我正在使用靴子的 property_tree 库。我正在寻找一种从对象中获取子节点的方法,但如果失败则ptree返回空。ptree我在 property_tree/examples/empty_ptree_trick.cpp 中遇到了一个很好的例子:

void process_settings(const std::string &filename)
{
    ptree pt;
    read_info(filename, pt);    
    const ptree &settings = pt.get_child("settings", empty_ptree<ptree>());
    std::cout << "\n    Processing " << filename << std::endl;
    std::cout << "        Setting 1 is " << settings.get("setting1", 0) << std::endl;
    std::cout << "        Setting 2 is " << settings.get("setting2", 0.0) << std::endl;
    std::cout << "        Setting 3 is " << settings.get("setting3", "default") <<     std::endl;
}

这正是我需要的。问题是编译器抱怨empty_ptree()函数不是boost:property_tree. 任何想法在哪里empty_ptree()

我在 VS2010 上使用 boost 1.44。

4

2 回答 2

2

我刚刚花了一整天的时间来回答这个问题!

这是我的解决方案。首先我使用了指针,而不是引用,因为你必须立即初始化它们。然后我刚刚捕获了异常并添加了一个新的 ptree。

using namespace boost::property_tree;

ptree r_pt;
ptree *c_pt;

read_xml( "file.xml" , r_pt);

try {
    c_pt = &(r_pt.get_child( "example" ));
}
catch (ptree_bad_path) {
    c_pt = &(r_pt.put_child( "example", ptree() ));
}

std::cout << "Setting 1 is " << c_pt.get("setting1", 0) << std::endl;

据我所知,他们希望我们使用 boost::optional 类型。但我只是一个初学者..

编辑 我刚刚找到了 empty_ptree<> 的实现。

template<class Ptree>
    inline const Ptree &empty_ptree()
    {
        static Ptree pt;
        return pt;
    }

我认为您可以将其添加到您的代码中并按照 empty_ptree_trick.cpp 中的说明使用它,但我现在坚持使用我的解决方案,直到我发现它实际上应该如何完成。

于 2011-03-04T17:53:44.637 回答
1
void process_settings(const std::string &filename)
{
    ptree pt;
    read_info(filename, pt);    
    const ptree &settings = pt.get_child("settings", ptree());
    std::cout << "\n    Processing " << filename << std::endl;
    std::cout << "        Setting 1 is " << settings.get("setting1", 0) << std::endl;
    std::cout << "        Setting 2 is " << settings.get("setting2", 0.0) << std::endl;
    std::cout << "        Setting 3 is " << settings.get("setting3", "default") <<     std::endl;
}

请注意,这将防止抛出 'boost::wrapexceptboost::property_tree::ptree_bad_path' 的实例

于 2020-12-01T00:40:24.427 回答