【Segment Fault】段错误解析

今天发现了几个容易导致段错误的代码;自己分析了一下,分享给大家!

段错误是什么?段错误是指访问的内存超出了系统给这个程序所设定的内存空间,例如访问了不存在的内存地址、访问了系统保护的内存地址、访问了只读的内存地址等等情况。

访问不存在的内存地址

#include<stdio.h>
#include<stdlib.h>
void main()
{
        int*ptr = NULL;
        *ptr = 0;
}

因为操作系统不会把任何数据保存在地址0及其附近,也不会把地址0~0xfff的页面映射到物理内存,所以任何对地址0的访问都会立刻导致段错误。*p = 0;会导致段错误

 

访问只读的内存地址

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void main()
{
        char*ptr = "test";
        strcpy(ptr, "TEST");
}

 

其实,char *ptr ="test"和constchar *ptr = "test" 是一样的,都是存在敞亮区,处于静态储存区,是只读的,不可修改的,”test”是固定存在.rdata段的。如果对只读的进行写操作,那么系统就会提示”segmentationfault”

 

栈溢出

栈溢出就是:栈溢出是由于C语言系列没有内置检查机制来确保复制到缓冲区的数据不得大于缓冲区的大小,因此当这个数据足够大的时候,将会溢出缓冲区的范围。(来自百度百科)

 #include<stdio.h>
#include<stdlib.h>
void main()

       main();
}


无限递归。。函数的调用也是有开销的,栈大小默认就1MB

  所以尽量在编代码中避免这些常犯的错误!

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值