Chinaunix首页 | 论坛 | 博客
  • 博客访问: 197450
  • 博文数量: 77
  • 博客积分: 1749
  • 博客等级: 上尉
  • 技术积分: 810
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-28 18:27
文章分类
文章存档

2012年(28)

2011年(49)

分类: C/C++

2011-11-12 20:44:11

所谓的段错误就是指访问的内存超出了系统所给这个程序的内存空间,通常这个值是由gd tr来保存的,他是一个48位的寄存器,其中的32位是保存由它指向的 gdt表,后13位保存 相应于gdt的下标,最后3位包括了程序是否在内存中以及程序的在cpu中的运行级别,指向 的gdt是由以64位为一个单位的表,在这张表中就保存着程序运行的代码段以及数据段的起 始地址以及与此相应的段限和页面交换还有程序运行级别还有内存粒度等等的信息。
Quote:  一旦一个程序发生了访问,就会产生相应的保护,于是segmentation fault就出现
  了通过上面的解释,段应该就是访问了不可访问的内存,这个区要么是不存在的,
  要么是受到系统保护的,还有可能是缺少文件或者文件损坏。寻找程序安装维修按列。
在编程中以下几类做法容易导致段错误,基本是是错误地使用引起的
  1)访问系统数据区,尤其是往 系统保护的最常见就是给一个指针以0地址
  2)内存越界(数组越界,变量类型不一致等) 访问到不属于你的内存区域解决方法我们在用C/语言写程序的时侯,的绝大部分工作都是需要我们来做的。实际上,内存管理是一个比较繁琐的工作,无论你多高明,经验多丰富,难 免会在此处犯些小错误,而通常这些错误又是那么的浅显而易于消除。但是手工“除虫”(debug),往往是效率低下且让人厌烦的,本文将就"段错误"这个 内存访问越界的错误谈谈如何快速定位这些"段错误"的语句。

1. 定义char *p = "Tomato_cat"; 并对p的值进行了改变,造成了Segmentation Fault
    改正:char p[] = "Tomato_cat";    就可以了。
2. 定义struct some *a; 然后直接给a赋值,造成了Segmentation Fault
    改正:a = (struct some *a)malloc(sizeof(struct some));   就可以了。
阅读(821) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~