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