Segmentation Fault_20230721

常见段错误(Common Segmentation Fault)

前言

C语言学习过程中,经常会碰到segmentation fault的错误,很多时候都能明显发现,昨晚运行动态规划程序的时候,不断报错,苦于找不到原因,所以在网上搜索导致段错误的常见原因,以飨有同类问题的读者。

  1. Modify the string literal(修改字符串常量)

    字符串常量储存在只读区域,下面的程序尝试会爆出段错误,因为程序员尝试在只读区域[1]的位置写入数据’n’,所以会报segmentation fault的错误。

在这里插入图片描述

  1. Access the address that is freed

下面代码创建一个整数指针变量p,并且赋值100,接着释放p指向的内存,然后间接引用*p,并且赋值80。编译器此时报错,禁止间接引用指针 p。这类指针称作悬挂指针,如果过程中间接引用此类指针,将引发segmentation fault或其它运行异常错误。

在这里插入图片描述

  1. Access the out-of-bound array index(访问数组下标超界)

数组访问下标越界,可能会导致不可预料的错误,程序可能报错或修改其它数组元素数据,下属程序arr[5]访问越界,对其进行赋值,发现q[1]的值更新到10,实际上它修改了(q+1)所指向的具体值。实际上,在C语言中,编译器不会对数组边界进行检查。

在这里插入图片描述

  1. Improper use of scanf

scanf 函数期待一个变量的地址输入,然后从终端接收到标准的输入值,此程序中,n的值为2,假定它的地址为0X1000。如果把n的值传入到输入的位置,那么函数就会从输入终端读取相应的数值,赋给2所指向的地址,这与程序的初衷是相违背,程序的希望把读入的值赋给0X1000所指向的内存。此时程序会报错,错误为segmentation fault.

在这里插入图片描述

  1. Stack overflow(栈溢出)

栈溢出可能与指针无关,甚至代码中不包含指针。栈溢出纯粹是疑问栈内存被耗尽,从而导致报错。这种内存内存崩溃可能源于数组过大,递归深度过高或者是变量太多,过程中需要特别注意数组定义,递归的结束条件设定或变量数量的控制。

在这里插入图片描述

  1. Dereferencing uninitialized pointer or null pointer(间接引用未初始化指针或空指针)

编程中常见的一类错误是,间接引用未初始的指针(野指针)或间接引用空指针,它可能导致不可预测的程序行为。当一个指针被视为有效指针,并尝试访问它所指向的内容时,如果之前没有初始化,那么就可能导致segmentation fault的错误。这可能导致数据损坏,程序错误或分段错误。

在这里插入图片描述

后记

段错误产生的原因是程序尝试访问不属于自己的空间。只要能在程序中避免这种行为,那么就可以避免段错误的发生。如果出现段错误,可以尝试从上面的几类可能原因着手,分别进行分析,找到根本原因。如果通过上述原因分析,还未清楚根本原因,此时就需要结束debugger工具进行分析,直至彻底找到相应的原因。

参考资料:

Segmentation Fault in C/C++ - GeeksforGeeks

ps://www.geeksforgeeks.org/segmentation-fault-c-cpp/)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值