Rapidxml导致奇怪的问题

Rapidxml causing weird problems

本文关键字:问题 Rapidxml      更新时间:2023-10-16

我在使用rapidxml时遇到了问题。下面的代码给了我输出:http://pastebin.com/352MxuQY
但是当我删除我附加节点的循环或"{}"时,我得到了很好的输出:http://pastebin.com/H0YQGwV1
为什么会这样?

rapidxml::xml_document<> andDoc;
ifstream andfile(PATH+XMLNAME);
vector<char> buffer((istreambuf_iterator<char>(andfile)), istreambuf_iterator<char>( ));
buffer.push_back('');
cout<<&buffer[0]<<endl; 
andDoc.parse<0>(&buffer[0]); 
xml_node<>* cos = andDoc.first_node("Data")->first_node("Classifiers");
xml_node<>* klda = andDoc.first_node("Data")->first_node("Kldas");
for(int i=0;i<1;i++)
{
    rapidxml::xml_document<> doc;
    ifstream myfile(cPATH+"0\c.xml");
    vector<char> buffer2((istreambuf_iterator<char>(myfile)), istreambuf_iterator<char>( ));
    buffer2.push_back('');
    cout<<&buffer2[0]<<endl; 
    doc.parse<0>(&buffer2[0]); 
    xml_node<>* cl = doc.first_node();
    xml_node<>* asd = doc.clone_node(cl);
    cos->append_node(asd);
    myfile.close();
}
std::ofstream file(PATH+XMLNAME);
if (file.is_open())
{
    file.clear();
    file << andDoc;
    file.close();
}

有点晚了,但我认为正在发生的事情是:RapidXML的clone_node并不像你想象的那样工作。

从文档中,增加了一些重点...


概要

xml_node<Ch>* clone_node(const xml_node< Ch > *source, xml_node< Ch > *result=0);

描述

克隆xml_node及其子节点和属性的层次结构。节点和属性是从此内存池中分配的。名称和值不会克隆,而是在克隆和源之间共享。可以选择将结果节点指定为第二个参数,在这种情况下,其内容将替换为克隆的源节点。当您想要克隆整个文档时,这很有用。


因此,正在发生的事情是,当xml_document"doc"在 for 循环结束时超出范围时,克隆节点的名称和值超出范围(因此丢失)。鉴于此限制,我无法诚实地看出clone_node有什么用。

我不确定如何最好地解决这个问题 - 这取决于您的实际需求,但您可能需要以某种方式将所有源文档保留在范围内,直到创建最终输出。