Ubuntu下Qt生成core查看Segmentation fault (core dumped)原因

core dump:

在UNIX系统中,常将“主内存”(main memory) 称为核心(core),因为在使用半导体作为内存材料之前,便是使用核心(core)。而核心映像(core image) 就是 “进程”(process)执行当时的内存内容。当进程发生错误或收到“信号”(signal) 而终止执行时,系统会将核心映像写入一个文件,以作为调试之用,这就是所谓的核心转储(core dump)。

有时程序并未经过彻底测试,这使得它在执行的时候一不小心就会找到破坏。这可能会导致核心转储(core dump)。幸好,现行的UNIX系统极少会面临这样的问题。即使遇到,程序员可以通过核心映像(core image)调试程序来找到错误原因。

用法:

  1. gcc -c :gcc编译时 加入-g参数:在Qt下:在pro文件添加如下命令:
    QMAKE_CC += -g
    
    QMAKE_CXX += -g
    
    QMAKE_LINK += -g
  2. 编译后,生成的可执行文件目录下打开控制台:

  3. ulimit -a:查看当前系统允许产生的core文件大小,一般在第一行为0.
  4. ulimit -c 1024:将core文件允许大小改为1k,还可以设置为unlimited,即无上限。

  5. 上面指令,当前终端生效,在用户的 ~/.bashrc 里加上 ulimit -c unlimited 来让特定的用户可以产生 core 文件

  6. ./xx:此时运行编译后的程序即可在当前目录生成core文件

  7. 最后gdb ./xx core 调试,即可查看程序终止情况。

 

更换core文件名和生成目录

#使core文件存到/corefile目录下,产生的文件名为 core-命令名-pid-时戳
echo "/corefile/core-%e-%p-%t" > /proc/sys/kernel/core_pattern 
     
#参数列表 : 
%p - insert pid into filename 添加 pid 
%u - insert current uid into filename 添加当前 uid 
%g - insert current gid into filename 添加当前 gid 
%s - insert signal that caused the coredump into the filename 添加导致产生 core 的信号 
%t - insert UNIX time that the coredump occurred into filename 添加 core 文件生成时的 unix 时间 
%h - insert hostname where the coredump happened into filename 添加主机名 
%e - insert coredumping executable name into filename 添加命令名

产生core dump的原因
内存访问越界
a) 由于使用错误的下标,导致数组访问越界。
b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有正常的使用结束符。
c) 使用strcpy, strcat, sprintf, strcmp,strcasecmp等字符串操作函数,将目标字符串读/写爆。
多线程程序使用了线程不安全的函数。
多线程读写的数据未加锁保护。
对于会被多个线程同时访问的全局数据,应该注意加锁保护,否则很容易造成coredump
非法指针
a) 使用空指针
b) 随意使用指针转换。一个指向一段内存的指针,除非确定这段内存原先就分配为某种结构或类型,或者这种结构或类型的数组,否则不要将它转换为这种结构或类型的指针,而应该将这段内存拷贝到一个这种结构或类型中,再访问这个结构或类型。这是因为如果这段内存的开始地址不是按照这种结构或类型对齐的,那么访问它时就很容易因为bus error而core dump。
堆栈溢出
不要使用大的局部变量(因为局部变量都分配在栈上),这样容易造成堆栈溢出,破坏系统的栈和堆结构,导致出现莫名其妙的错误。

 

 

Linux下,当一个Qt程序打包后,在运行时出现"Segmentation fault (core dumped)"的错误,通常是由于程序访问了不被允许的内存地址或发生了内存溢出等问题导致的。 首先,我们可以尝试查看生成CoreDump文件,以便获取更多关于错误的详细信息。在终端中执行以下命令: ```shell $ gdb <path_to_your_program> core ``` 其中,`<path_to_your_program>`是你的程序的路径,`core`是生成CoreDump文件名。进入gdb调试界面后,可以使用`bt`命令查看调用栈信息,以确定错误发生的位置。 如果你的程序依赖于一些第三方库,那么这个问题可能与库版本不匹配有关。你可以尝试重新编译这些库或者更新到更新的版本。 另外,一些常见的导致该错误的问题包括: 1. 空指针引用:程序中使用了一个空指针,例如没有对指针进行初始化或没有正确判断指针是否为NULL。 2. 数组溢出:程序中访问了超出数组边界的元素,导致越界访问了不被允许的内存地址。 3. 内存泄漏:程序动态申请的内存没有被正确释放,导致内存溢出。 4. 未初始化的变量:使用了一个未初始化的变量,其值是不确定的,可能导致错误的操作。 为了解决这些问题,你可以使用一些工具来帮助调试,例如`valgrind`(检测内存泄漏和越界访问)或者`gdb`(动态调试器)等。这些工具会提供更详细的错误信息,帮助你定位和解决问题。 总之,"Segmentation fault (core dumped)"错误的出现通常是由于程序访问了不被允许的内存地址或发生了内存溢出等问题导致的。使用调试工具定位错误,修改代码以避免这些问题的出现是解决该错误的关键步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值