Segmentation fault:你是否曾经为这头疼??

Segmentation fault 也是我们常说的段错误,是编写代码过程中很容易遇到的事情。有时候你也许会感叹无法避免这种情况的发生,甚至常常为这位“熟客”感到头疼。

段错误,总结起来无非是两种情况导致:内存越界,访问非法内存。

 

1、内存越界

内存越界就是指内存输入超出了预分配的空间大小,导致系统异常。

如下面一段代码:

1  #define MAXNUM 1024

2  unsigned char array[MAXNUM ];

3  memset(array,0,MAXNUM );

4  ```

5  int num;

6  array[num] = ‘a’ ;

上段代码是一个不定时炸弹。为什么这么说,代码的第五行定义了一个int型变量num , 但并没对num 赋初始值,过程中也没有对 nun 赋值的操作语句。所以 num 的值是编译器非配的一个随机值,当 num > MAXNUM 的时候就出现了内存越界。危险的是,你不知道这个炸弹什么时候会爆炸。

2、访问了非法内存

所谓访问了非法内存,就是内存中有写敏感区域是被保护的,而用户没有操作权限,当我们尝试去“动”这块内存的时候就会出现了段错误。

如下面一段代码:

1  #define MAXNUM 5

2  buff[MAXNUM ] = “一串字符串”

3  ```

4  printf(“ %s ” , buff);

正常来说上面一段代码是没问题的,但如果我们把printf语句唔写成:printf(“ %s ” , buff[i]); 那么printf就会把buff[i]当做传入的字符串入口地址,当buff[i] 正处于内存保护区的时候,就会出现段错误。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值