segment fault 是段错误,通常在非法内存访问,读写的时候会报这个错误。 一、比较常见的错误情况如下 1:赋值操作(非法地址写) 2:数组越界 (非法地址读 或 写) 相当于执行了putchar(a[3]),a[3]是"\0",在内存中是00,也是个常见的非法内存访问 3:内存(字符串)拷贝 (非法地址读 或 写)   4:非法地址执行(栈溢出,任意地址执行时可能出现这种情况) 这条指令 == call 0xdeadbeef,0xdeadbeef 是个非法地址,所以会报段错误。 还有一些暂时想不起来的,不过原理也是非法内存访问和读写。 二、知道了错误的成因就可以知道怎么检测了。 1:printf 大法 最简单的往往是最常用的,printf一下地址,变量。 2:调试的方法 利用gdb, asan这些工具可以很快定位到segment fault的地址 是一个0地址写的seg fault 3:catchsegv 指令 是一个输出segfault 时寄存器的内容。 暂时想到这么多,写的东西也不是很深,其实段错误是很好检测的,因为一旦发生段错误,os就会请求中断或者发出信号来结束程序。要在编译时候检测,借助gcc+asan这种内存检查工具才可行,即便是asan也可能存在疏漏。windows下也有成熟独立的体系,原理相同就不多说了。
点赞 评论

相关推荐

牛客221235529号:土木只用写:土木 男 能吃苦 就好了
点赞 评论 收藏
分享
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
牛客网
牛客企业服务