- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
简而言之,产生段错误就是访问了错误的内存段,一般是你没有权限,或者根本就不存在对应的物理内存,尤其常见的是访问0地址.?一般来说,段错误就是指访问的内存超出了系统所给这个程序的内存空间,通常这个值是由gdtr来保存的,他是一个48位的寄存器,其中的32位是保存由它指向的gdt表,后13位保存相应于gdt的下标,最后3位包括了程序是否在内存中以及程序的在cpu中的运行级别,指向的gdt是由以64位为一个单位的表,在这张表中就保存着程序运行的代码段以及数据段的起始地址以及与此相应的段限和页面交换还有程序运行级别还有内存粒度等等的信息。一旦一个程序发生了越界访问,cpu就会产生相应的异常保护,于是segmentation?fault就出现了.?在编程中以下几类做法容易导致段错误,基本是是错误地使用指针引起的?1)访问系统数据区,尤其是往??系统保护的内存地址写数据????最常见就是给一个指针以0地址?2)内存越界(数组越界,变量类型不一致等)?访问到不属于你的内存区域?解决方法?我们在用C/C++语言写程序的时侯,内存管理的绝大部分工作都是需要我们来做的。实际上,内存管理是一个比较繁琐的工作,无论你多高明,经验多丰富,难?免会在此处犯些小错误,而通常这些错误又是那么的浅显而易于消除。但是手工“除虫”(debug),往往是效率低下且让人厌烦的,本文将就段错误这个?内存访问越界的错误谈谈如何快速定位这些段错误的语句。?下面将就以下的一个存在段错误的程序介绍几种调试方法:??????1??dummy_function?(void)??????2??{??????3??????????unsigned?char?*ptr?=?0x00;??????4??????????*ptr?=?0x00;??????5??}??????6??????7??int?main?(void)??????8??{??????9??????????dummy_function?();?????10?????11??????????return?0;?????12??}???作为一个熟练的C/C++程序员,以上代码的bug应该是很清楚的,因为它尝试操作地址为0的内存区域,而这个内存区域通常是不可访问的禁区,当然就会出错了。我们尝试编译运行它:?xiaosuo@gentux?test?$?./a.out?段错误???果然不出所料,它出错并退出了。?1.利用gdb逐步查找段错误:?这种方法也是被大众所熟知并广泛采用的方法,首先我们需要一个带有调试信息的可执行程序,所以我们加上“-g?-rdynamic的参数进行编译,然后用gdb调试运行这个新编译的程序,具体步骤如下:?xiaosuo@gentux?test?$?gcc?-g?-rdynamic?d.c?xiaosuo@gentux?test?$?gdb?./a.out?GNU?gdb?6.5?Copyright?(C)?2006?Free?Software?Foundation,?Inc.?GDB?is?free?software,?covered?by?the?GNU?General?Public?License,?and?you?are?welcome?to?change?it?and/or?distribute?copies?of?it?under?certain?conditions.?Type?show?copying?to?see?the?conditions.?There?is?absolutely?no?warranty?for?GDB.??Type?show?warranty?for?details.?This?GDB?was?configured?as?i686-pc-linux-gnu...Using?host?libthread_db?library?/lib/libthread_db.so.1.?(gdb)?r?Starting?program:?/home/xiaosuo/test/a.out?Program?received?signal?SIGSEGV,?Segmentation?fault.?0in?dummy_function?()?at?d.c:4?4???????????????*ptr?=?0x00;?(gdb)??????????????????????????哦?!好像不用一步步调试我们就找到了出错位置d.c文件的第4行,其实就是如此的简单。?从这里我们还发现进程是由于收到了SIGSEGV信号而结束的。通过进一步的查阅文档(man?7?signal
文档评论(0)