使用libxml解析文件时,我得到了一个奇怪的段错误.当我将它编译为32位应用程序时,此代码以前工作.我将其更改为64位应用程序,它停止工作.
seg错误出现在“if(xmlStrcmp(cur-> name,(const xmlChar *)”servers“))”
cur-> name是一个const xmlChar *,它指向一个表示其out out界限的地址.但是当我调试并转到该内存位置时,该数据是正确的.
int XmlGetServers(){xmlDocPtr doc;xmlNodePtr cur;doc = xmlParsefile("Pin.xml");if (doc == NulL){ std::cout << "\n Pin.xml not parsed successfully." << std::endl; return -1;}cur = xmlDocgetRootElement(doc);if (cur == NulL){ std::cout << "\n Pin.xml is empty document." << std::endl; xmlFreeDoc(doc); return -1;}if (xmlStrcmp(cur->name,(const xmlChar *) "servers")){ std::cout << "\n ERROR: Pin.xml of the wrong type,root node != servers." << std::endl; xmlFreeDoc(doc); return -1;}}
在cur初始化之前,name参数是
name : name Details:0xed11f72000007fff
初始化cur后,name参数为
Name : name Details:0x64c43000000000
引用的XML文件
系统:
*** 作系统:Redhat Enterprise Linux 6.4 64位
海湾合作委员会:4.4.7-3
包:libxml2-2.7.6-8.el6_3.4.x86_64
最佳答案我按原样拿了你的代码,并补充说:#include
然后将函数重命名为main()并在x86-64 Fedora 22上编译它,它有libxml2 2.9.2
生成的代码使用示例文件成功运行,没有segfaults.甚至valgrind发现没有内存访问冲突.作为证明,得到的缩写strace日志如下:
stat("Pin.xml",{st_mode=S_IFREG|0644,st_size=362,...}) = 0stat("Pin.xml",...}) = 0open("Pin.xml",O_RDONLY) = 3lseek(3,SEEK_CUR) = 0read(3,"
虽然这是一个稍微新的libxml2和gcc的Fedora,但这种差异并不重要.这里的答案是,这里显示的代码没有任何问题.我觉得它没有错.
但它显然是更大应用程序的一部分,并且您的内存损坏正在应用程序的其他部分中发生,并且只有在应用程序执行到达此部分时才会显示.
关于C的问题在于,仅仅因为代码在特定点崩溃,并不意味着这个特定的代码行就是问题所在.想出一个简单的例子应该不难:
#include
这里的错误显然出现在strcpy行中.但是代码运行得很好,从0到99打印100个数字,并在main()返回时崩溃.但是,显然,“返回0”不是错误所在的位置.
这类似于您的应用程序所发生的情况.某些内存损坏在某些时候发生,在代码尝试解析XML文件之前,这不会对代码执行产生实质性影响.
欢迎来到C.
总结以上是内存溢出为你收集整理的c – 读取xml时出现Out of bounds错误全部内容,希望文章能够帮你解决c – 读取xml时出现Out of bounds错误所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)