linux故障处理命令时出现错误,Linux编程时出现Segmentation fault错误的处理办法

有些开发者在Linux下进程编程,使用GDB调试时发现了一个Segmentation fault错误。这个错误主要是访问了错误的内存段引起的,可能是没有权限或者是内存段不存在,这个问题如何处理呢?

1388c69541ec7e6db0163ce062b9384a.png

方法如下:

这个错误是怎么导致的呢?原来是在定义一个char类型的指针,然后就直接对这个指针进行字符串的相关操作。例如:

char *c1;

for(i=0; i《n;i++)

{

*c1 = getchar();

c1++;

}

代码意思大概是这样,这是很多开发者会犯的问题。这个指针危险啊,要谨慎对待,就拿这里来说,这样给指针赋值,我们并不知道这指针指向的是哪里呢,如果写的数据覆盖了关键区域数据那可能会有灾难性的后果,这就是访问了不该访问的地方。解决的办法是什么呢,告诉这个指针到该到的地方,我用malloc为该指针将要指向的字符串申请一段空间,这样就会指明系统分配一段安全的空间,不会在把内存关键区域分给你了。这样你就可以安全操作了。

这个例子告诉我们指针是不能乱用的,如果指针指向错误的内存,导致编程时出现Segmentation fault错误,还可以用上面的办法处理,如果指向其他区域,还会导致更严重的后果。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值