Linux下的段误(Segmentation fault)产生的原因及调试方法(经典).docVIP

  • 159
  • 0
  • 约4.41万字
  • 约 6页
  • 2017-03-05 发布于贵州
  • 举报

Linux下的段误(Segmentation fault)产生的原因及调试方法(经典).doc

Linux下的段误(Segmentation fault)产生的原因及调试方法(经典)

Linux下的段错误(Segmentation fault)产生的原因及调试方法(经典) 2009-04-05 11:25 简而言之,产生段错误就是访问了错误的内存段,一般是你没有权限,或者根本就不存在对应的物理内存,尤其常见的是访问0地址. 一 般来说,段错误就是指访问的内存超出了系统所给这个程序的内存空间,通常这个值是由gdtr来保存的,他是一个48位的寄存器,其中的32位是保存由它指 向的gdt表,后13位保存相应于gdt的下标,最后3位包括了程序是否在内存中以及程序的在cpu中的运行级别,指向的gdt是由以64位为一个单位的 表,在这张表中就保存着程序运行的代码段以及数据段的起始地址以及与此相应的段限和页面交换还有程序运行级别还有内存粒度等等的信息。一旦一个程序发生了 越界访问,cpu就会产生相应的异常保护,于是segmentation fault就出现了. 在编程中以下几类做法容易导致段错误,基本是是错误地使用指针引起的 1 访问系统数据区,尤其是往 系统保护的内存地址写数据 最常见就是给一个指针以0地址 2 内存越界 数组越界,变量类型不一致等 访问到不属于你的内存区域 解决方法 我 们在用C/C++语言写程序的时侯,内存管理的绝大部分工作都是需要我们来做的。实际上,内存管理是一个比较繁琐的工作,无论你多高明,经验多丰富,难 免会在此处犯些小错误,而通常

文档评论(0)

1亿VIP精品文档

相关文档