如何知道Linux中的程序在哪个地址崩溃
How to know what address a program in Linux crashes at?
我有一个在Linux上运行的程序,它神秘地崩溃了。我已经知道知道它在哪里崩溃的一种方法是使用GDB。但我不想每次重新启动它时都连接到它(因为我正在测试它,所以经常这样做)。有别的办法吗?
首先使用ulimit -c unlimited
允许崩溃的程序写入核心转储。
程序崩溃后,您将发现一个核心转储文件,称为core
,如果您的程序是多线程的,则可能称为core.<pid>
。
您可以将其加载到GDB中,以使用gdb program core
检查崩溃点的状态。
首先执行ulimit -c unlimited
,这样程序将留下一个核心转储。然后,当它崩溃时,使用核心转储调用gdb
来读取程序崩溃时的状态
您可以配置操作系统在程序崩溃时转储核心文件。然后,您可以检查内核以确定崩溃位置。
->编译启用GDB标志的代码
gcc - 0 <二进制名称> -g
->在gdb中运行可执行文件。gdb & lt;二进制名称>
之后有办法找到崩溃的位置:1. 逐步执行。2. 运行代码,它崩溃(如预期的那样),在GDB中输入"where"(不带引号),它给出了回溯。从那里,你可以找到地址。
这里有一个很好的GDB快速指南:http://www.cs.cmu.edu/~gilpin/tutorial/
相关文章:
- 当回溯以零开始时,如何调试崩溃
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 内联映射初始化的动态atexit析构函数崩溃
- 执行函数时导致崩溃的变量
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 程序崩溃并显示"std::out_of_range"错误
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- CoInitialize()在单独的线程上崩溃而不返回
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 使用调试/崩溃报告将应用程序部署到客户端
- iOS崩溃报告象征无DSYM-二进制中看到的地址之外的符号地址
- C++ 尝试通过内存中的地址调用函数时程序崩溃(如何修复?
- 从地址调用函数时,C 程序崩溃
- 如何知道Linux中的程序在哪个地址崩溃
- 崩溃报告中的CPU寄存器地址在分析中如何有用