常见的导致 coredump 的原因

1 C 语言程序常见的 coredump 原因及分析

C 语言编译生成的二进制程序在 Linux/Unix 系统下,最常见的崩溃信号是 SIGSEGV (段错误),会导致生成 core 文件(coredump)。

下面按发生频率从高到低,列出最常见的导致 coredump 的原因。

1.1 常见 coredump 原因排行

排名 原因 典型触发场景 示例代码
1 空指针解引用 使用 NULL 或未初始化的指针进行读写 char *p = NULL; *p = 'x';
2 野指针 / 悬空指针 使用已经 free() 或生命周期结束后的指针 free(ptr); *ptr = 1;
3 数组/缓冲区越界 访问超过数组实际大小的下标 int arr[10]; arr[10] = 5;
4 栈溢出 (Stack Overflow) 递归过深、声明超大局部数组 char buf[10*1024*1024]; 或无限递归
5 堆内存使用错误 多次 free、释放后继续使用、堆缓冲区溢出 free(ptr); free(ptr);
6 scanf 格式错误 忘记加取地址符 & int x; scanf("%d", x);
7 不安全字符串操作 strcpystrcatsprintf 等导致越界 char buf[8]; strcpy(buf, "too long string");
8 除零错误 整数或浮点数除以 0(触发 SIGFPE) int a = 10 / 0;
9 非法内存访问 修改只读内存区域(如字符串字面量) char *s = "hello"; s[0] = 'H';
10 多线程数据竞争 未加锁访问共享变量,导致内存损坏 多个线程同时写同一全局变量
11 未初始化的指针 指针未赋值就直接使用 int *p; *p = 100;
12 返回局部变量地址 函数返回指向栈上临时变量的指针 char* func() { char buf[100]; return buf; }

1.2 其他可能导致 coredump 的情况

  • 调用 abort()assert() 失败(触发 SIGABRT)
  • 地址未对齐访问(触发 SIGBUS)
  • malloc 返回 NULL 后仍继续使用该指针
  • C++ 中未捕获的异常

1.3 如何预防和快速定位 coredump

1.3.1 编译时推荐选项

bash 复制代码
gcc -g -O0 -Wall -Wextra -fsanitize=address -fno-omit-frame-pointer program.c -o program

常用选项说明:

  • -g:生成调试信息
  • -fsanitize=address:开启 AddressSanitizer(强烈推荐)
  • -Wall -Wextra:开启更多编译警告

1.3.2 开启系统 core dump 生成

Bash 复制代码
ulimit -c unlimited

1.3.3 使用 gdb 分析 core 文件

Bash 复制代码
gdb ./program core

gdb 中常用命令:

  • bt ------ 查看崩溃时的调用栈
  • info locals ------ 查看当前函数的局部变量
  • print <变量名> ------ 查看变量值

1.3.4 推荐调试工具

  • AddressSanitizer (ASan)
  • Valgrind
  • UndefinedBehaviorSanitizer (UBSan)

1.4 总结:最常见的 Top 5 原因

  1. 空指针 / 未初始化指针解引用
  2. 数组/缓冲区越界(尤其是字符串操作)
  3. Use After Free(释放后继续使用)
  4. 栈溢出
  5. scanf 等输入函数忘记加 &
相关推荐
咸甜适中1 小时前
rust格式化输出(println!、format!、...)
开发语言·rust
CQU_JIAKE1 小时前
【a]4.25
开发语言
张健11564096481 小时前
std::ranges、std::views和懒加载
开发语言·c++
gCode Teacher 格码致知1 小时前
Javascript提高:一个彩色小球在画布边界内反弹并留下渐变轨迹-由Deepseek产生
开发语言·javascript
Z文的博客1 小时前
【避坑实录】Qt 4.8.6 + Paho MQTT C客户端 + OpenSSL静态链接的血泪史
c语言·开发语言·qt·嵌入式linux
神仙别闹1 小时前
基于Python实现上下消化道病历分类
开发语言·python·分类
一行代码一行诗++2 小时前
转义字符和语句
c语言·开发语言·算法
逻辑驱动的ken2 小时前
Java高频面试考点场景题16
java·开发语言·面试·职场和发展·求职招聘
xingpanvip2 小时前
星盘接口开发文档:天象盘接口指南
android·开发语言·python·php·lua