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下也有成熟独立的体系,原理相同就不多说了。
点赞 评论

相关推荐

05-13 02:01
已编辑
惠州学院 前端工程师
安静的少年在求佛:建议把公司名字写到标题。以后有人想搜就能直接搜到
点赞 评论 收藏
分享
湫湫湫不会java:1.在校经历全删了2.。这些荣誉其实也没啥用只能说,要的是好的开发者不是好好学生3.项目五六点就行了,一个亮点一俩行,xxx技术解决,xxx问题带来xxx提升。第一页学历不行,然后啥有价值的信息也没有,到第二页看到项目了,第一个项目九点,第二个项目像凑数的俩点。总体给人又臭又长,一起加油吧兄弟
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务