在linux下运行可执行文件的时候出现了以下错误:
error:segmentation fault core dumped
解决方法:
#查看core文件大小判断是否可写
$ ulimit -a
real-time non-blocking time (microseconds, -R) unlimited
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 31265
max locked memory (kbytes, -l) 1010876
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 31265
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
#如果core file size是0就需要修改文件大小
$ ulimit -c unlimited
#查看是否修改成功
$ ulimit -c
unlimited
#通过man 5 core查看core文件路径
$ man 5 core
$ cat /proc/sys/kernel/core_pattern
|/usr/share/apport/apport -p%p -s%s -c%c -d%d -P%P -u%u -g%g -- %E
# 使用echo来修改文件路径发现权限不够
$ echo "/home/wm/projects/Webserver/bin/core-%e-%p-%t"> /proc/sys/kernel/core_pattern
bash: /proc/sys/kernel/core_pattern: Permission denied
# 使用命令关闭apport.service服务
$ sudo systemctl disable apport.service
# 查看core路径
$ cat /proc/sys/kernel/core_pattern
core
#再次运行发现生成core
$ ll
total 8880
drwxrwxr-x 2 wm wm 4096 8月 17 09:50 ./
drwxrwxr-x 8 wm wm 4096 8月 16 22:56 ../
-rw------- 1 wm wm 71880704 8月 17 09:50 core.33594
然后gdb测试
#启动gdb
gdb 可执行文件 core
使用bt命令回溯详细错误:
段错误原因
Segmentation fault (core dumped)多为内存不当操作造成。空指针、野指针的读写操作,数组越界访问,破坏常量等。对每个指针声明后进行初始化为NULL是避免这个问题的好办法。排除此问题的最好办法则是调试。
更为详细的原因:
(1)内存访问越界
a) 由于使用错误的下标,导致数组访问越界
b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有正常的使用结束符
c) 使用strcpy, strcat, sprintf, strcmp, strcasecmp等字符串操作函数,将目标字符串读/写爆。应该使用strncpy, strlcpy, strncat, strlcat, snprintf, strncmp, strncasecmp等函数防止读写越界。
(2)多线程程序使用了线程不安全的函数。
(3)多线程读写的数据未加锁保护。
对于会被多个线程同时访问的全局数据,应该注意加锁保护,否则很容易造成core dump
(4)非法指针
a) 使用空指针
b) 随意使用指针转换。一个指向一段内存的指针,除非确定这段内存原先就分配为某种结构或类型,或者这种结构或类型的数组,否则不要将它转换为这种结构或类型的指针,而应该将这段内存拷贝到一个这种结构或类型中,再访问这个结构或类型。这是因为如果这段内存的开始地址不是按照这种结构或类型对齐的,那么访问它时就很容易因为bus error而core dump.
(5)堆栈溢出。
不要使用大的局部变量(因为局部变量都分配在栈上),这样容易造成堆栈溢出,破坏系统的栈和堆结构,导致出现莫名其妙的错误。
原文链接:
段错误
段错误