免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3683 | 回复: 3

[函数] TiXmlDocument 栈上对象析构问题 [复制链接]

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
发表于 2016-05-25 17:42 |显示全部楼层
问题背景:在栈上创建了一个TiXmlDocument对象,运行了报错: *** glibc detected *** ./exe_name: free(): invalid pointer: 0x00000000006ab128 ***
              但是将在栈上创建对象改为在堆上创建,用完后delete就没有这个问题。
              或者将这个对象声明为static(程序执行过程中不执行析构),也是没有这个问题

我是将TiXmlDocument封装在一个类中,相关伪代码如下:
class A
{
private:
    //TiXmlDocument *m_doc;
    TiXmlDocument m_doc;
}

A::func()
{
    //m_doc = new TiXmlDocument ();
    //m_doc->LoadFile(strConfigFile);

    m_doc.LoadFile(strConfigFile);
    //...get some date
}
init()
{
    A a;
    a.func();
}
main()
{
    init();
}

报错时堆栈信息如下:
  1. Program terminated with signal 6, Aborted.
  2. #0  0x0000003ce4a30265 in raise () from /lib64/libc.so.6
  3. (gdb) bt
  4. #0  0x0000003ce4a30265 in raise () from /lib64/libc.so.6
  5. #1  0x0000003ce4a31d10 in abort () from /lib64/libc.so.6
  6. #2  0x0000003ce4a6a9bb in __libc_message () from /lib64/libc.so.6
  7. #3  0x0000003ce4a7247f in _int_free () from /lib64/libc.so.6
  8. #4  0x0000003ce4a728db in free () from /lib64/libc.so.6
  9. #5  0x00002b434875dc43 in _M_dispose (this=<value optimized out>, __in_chrg=<value optimized out>)
  10.     at /opt/gccsrc/gcc-4.6.3/x86_64-unknown-linux-gnu/libstdc++-v3/include/bits/basic_string.h:235
  11. #6  std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string (this=<value optimized out>, __in_chrg=<value optimized out>)
  12.     at /opt/gccsrc/gcc-4.6.3/x86_64-unknown-linux-gnu/libstdc++-v3/include/bits/basic_string.h:534
  13. #7  0x000000000040c7e4 in TiXmlDocument::~TiXmlDocument (this=0x7fff1c90b248, __in_chrg=<value optimized out>) at ../../xml/include/tinyxml.h:1409
  14. #8  0x000000000040b370 in Config::~Config (this=0x7fff1c90b200, __in_chrg=<value optimized out>) at config.cc:10
  15. #9  0x0000000000406c97 in InitFromConfig (workpath=0x7fff1c90bb8d "/opt//src/../data") at main.cc:138
  16. #10 0x0000000000406d04 in Init (argc=4, argv=0x7fff1c90b4f8) at main.cc:153
  17. #11 0x0000000000406ee3 in main (argc=4, argv=0x7fff1c90b4f8) at main.cc:72
复制代码
求指教,多谢

论坛徽章:
0
发表于 2016-05-25 22:52 |显示全部楼层
珍惜生命,远离TinyXML,还是换用pugixml吧,

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
发表于 2016-05-26 09:58 |显示全部楼层
回复 2# drangon


    .。。。。

论坛徽章:
0
发表于 2016-05-28 22:56 |显示全部楼层
TINYXML 析构是这样的

m_doc.clear()  //在对象析构之前一定要调用这个.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP