记录 debian 下应用程序崩溃调试方法
程序越界可以定位到越界的位置附近
debian 操作系统,如果不支持需要查看是否存在对应的可执行文件
- ulimit -c unlimited
- # 设置输出大小 生成core 文件
-
- sudo apt install gdb
- # 安装 gdb 调试工具
生成的 core 文件和应用程序同一层目录
现在需要制造一个越界的应用程序,如下
- #include
-
- /* 目标 dump 点 */
- void func_fault(void)
- {
- int array[10];
- for (int i = 0; i < 1000000; i++)
- {
- array[i] = i;
- }
- }
-
- int main(int argc, char* argv[])
- {
- func_fault();
- printf("hello world\r\n");
- return 0;
- }
编译程序并运行程序,如下,core dumped 表示有 dump 文件生成
- gcc main.c -o main
- ./main
- gdb ./main ./core
- # 使用 gdb 调试程序 ./main 使用的 ./core
-
- (gdb)bt
- # 进一步定位溢出位置
-
- (gdb)q
- # 退出 gdb
如图所示:可以定位到问题出现在函数 func_fault 中,可以定位出溢出位置