Linux下的段错误(Segmentation fault)
段错误是指:访问了系统分配给程序的内存空间之外起的内存空间,比如:
- 访问不存在的地址
- 访问受系统保护的地址
- 访问了只读内存地址
- 内存访问越界
要注意的:
-
使用strcpy, strcat, sprintf, strcmp, strcasecmp等字符串操作函数,将目标字符串读/写爆。应该使用strncpy, strlcpy, strncat, strlcat, snprintf, strncmp, strncasecmp等函数防止读写越界。
-
初始化指针后,尽量使用malloc分配一个内存空间,或者在初始化的时候就分配,以防内存访问越界。
-
puts()函数时中参数为一个字符时,会触发越界访问,因为字符只是一个值,没有结束符‘\0’,字符串处理函数会找不到结束符,就一直在内存中找下去,造成内存访问越界。相应的字符串操作函数更应该注意!!!
-
有时候可能会访问只读的内存,比如试图修改一个字符串常量的内容,字符串常量编译后放在
.rodata中,是只读的 -
访问受系统保护的地址,最常见的就是给指针0地址,然后去访问。
-
访问了不存在的内存,比如引用了一个空指针
-
还有,涉及到字符串处理的时候特别容易内存访问越界,因为大多数字符串相关的处理操作都是以结束符
\0作为结束的标志的!
1 使用非法的内存地址(指针),包括使用未经初始化及已经释放的指针、不存在的地址、受系统保护的地址,只读的地址等,这一类也是最常见和最好解决的段错误问题,使用GDB print一下即可知道原因。
2 内存读/写越界。包括数组访问越界,

段错误在Linux中通常发生在访问无效内存时,如访问不存在、受保护或只读地址,内存越界,使用未初始化或已释放的指针。避免这类问题的方法包括使用安全的字符串操作函数,正确管理内存,避免对C++对象的只读内存进行写操作,确保函数不返回局部对象的引用或地址,限制栈中大数组的定义,以及在多线程编程中使用互斥锁。了解并处理段错误是Linux编程中必不可少的知识。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



