电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

Linux下segmentfault的调试VIP免费

Linux下segmentfault的调试_第1页
1/13
Linux下segmentfault的调试_第2页
2/13
Linux下segmentfault的调试_第3页
3/13
Linux 下的段错误产生 的原因及调试方法简而言之,产生段错误就是访问了错误的内存段,一般是你没有权限,或者根本就不存在对应的物理内存,尤其常见的是访问 0 地址.一般来说,段错误就是指访问的内存超出了系统所给这个程序的内存空间,通常这个值是由 gdtr 来保存的,他是一个 48位的寄存器,其中的 32位是保存由它指向的 gdt 表,后13位保存相应于 gdt 的下标,最后 3位包括了程序是否在内存中以及程序的在 cpu 中的运行级别,指向的 gdt 是由以 64位为一个单位的表 ,在这张表中就保存着程序运行的代码段以及数据段的起始地址以及与此相应的段限和页面交换还有程序运行级别还有内存粒度等等的信息。一旦一个程序发生了越界 访问,cpu 就会产生相应的异常保护,于是segmentation fault 就出现了.在编程中以下几类做法容易导致段错误,基本是是错误地使用指针引起的1)访问系统数据区,尤其是往 系统保护的内存地址写数据最常见就是给一个指针以 0 地址2)内存越界(数组越界,变量类型不一致等)访问到不属于你的内存区域解决方法我们在用 C/C++语言写程序的时侯,内存管理的绝大部分工作都是需要我们来做的。实际上,内存管理是一个比较繁琐的工作,无论你多高明,经验多丰富,难 免会在此处犯些小错误 ,而通常这些错误又是那么的浅显而易于消除。但是手工 “除虫”(debug),往往是效率低下且让人厌烦的,本文将就"段错误"这个 内存访问越界的错误谈谈如何快速定位这些"段错误"的语句。下面将就以下的一个存在段错误的程序介绍几种调试方法:1dummy_function (void)2{3 unsigned char *ptr =0x00;4 *ptr = 0x00;5}67 int main (void)8{9 dummy_function ();1011return 0;12}作为一个熟练的 C/C++程序员,以上代码的 bug 应该是很清楚的,因为它尝试操作地址为0 的内存区域,而这个内存区域通常是不可访问的禁区,当然就会出错了。我们尝试编译运行它:xiaosuo@gentux test $ ./a.out段错误果然不出所料,它出错并退出了。1.利用 gdb 逐步查找段错误 :这种方法也是被大众所熟知并广泛采用的方法,首先我们需要一个带有调试信息的可执行程序,所以我们加上“-g -rdynamic"的参数进行编译,然后用 gdb 调试运行这个新编译的程序,具体步骤如下:xiaosuo@gentux test $ gcc -g -rdynamic d.cxiaosuo@gentux test $ gdb ./a.outGNU gdb 6.5Copyright (C)2006Free Software Foundation,Inc.GDB is free softwar...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

Linux下segmentfault的调试

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部