今天,我试图从我的项目中查找内存泄漏,然后我看到了下面的示例代码
std::string VersionValue("1.0");
std::string EncodingValue("UTF-8");
rapidxml::xml_document<> XMLDoc;
rapidxml::xml_node<> * pHeaderNode = XMLDoc.allocate_node(rapidxml::node_declaration);
pHeaderNode->append_attribute(XMLDoc.allocate_attribute("version", VersionValue.c_str()));
pHeaderNode->append_attribute(XMLDoc.allocate_attribute("encoding", EncodingValue.c_str()));我打开了rapidxml代码,在allocate_attribute()中看到了它的分配内存
xml_attribute<Ch> *attribute = new(memory) xml_attribute<Ch>;在append_attribute()内部,它将内存分配给其成员变量。没有为xml_document声明析构函数。那么它如何删除属性呢?从上面的示例代码中返回0内存泄漏。怎么可能?
发布于 2018-04-09 14:18:51
正如评论中提到的,新的位置是答案。
这种行为是rapidxml的主要优点之一,也是最常见的问题之一:它不复制作为参数传递的任何数据。
例如,如果您的代码如下所示:
rapidxml::xml_document<> XMLDoc;
rapidxml::xml_node<> * pHeaderNode =
XMLDoc.allocate_node(rapidxml::node_declaration);
{
std::string VersionValue("1.0");
std::string EncodingValue("UTF-8");
pHeaderNode->append_attribute(XMLDoc.allocate_attribute("version", VersionValue.c_str()));
pHeaderNode->append_attribute(XMLDoc.allocate_attribute("encoding", EncodingValue.c_str()))
}..。然后,您通常会遇到重大问题,因为属性字符串将超出作用域,但是rapidxml将继续保存指向它们的陈旧指针。
https://stackoverflow.com/questions/49628558
复制相似问题