c++ - 在回溯中 _start 和 main 之前看到的函数调用

标签 c++ linux qt gcc backtrace

我从同事那里收到了我的程序(在 RHEL 5.3 上运行的 qt 应用程序)的回溯,在分析它时我发现了一些我无法解释的东西。如果查看此回溯,您会注意到 main 和 _start 的跟踪。但在此之前,我们看到 _ZN19datalog_render_area9prepStripEh 和 _ZN12QMutexLockerD1Ev 在我的程序中。我怎样才能看到我的一些函数在 _start 和 main.c 之前被调用。那不是不可能吗? (请原谅我回溯的布局)

Funct Addr| Instr. Addr | FunctionSymbol  
----------|-------------|----------------------------------------------------------|  
0x8060bf2 | 0x8060dc0   | _Z11print_tracev  
0x8061386 | 0x806141c   | _Z15myMessageOutput9QtMsgTypePKc  
0x822b558 | 0x822b598   | _ZN5QListIP13QStandardItemEixEi  
0x8229ece | 0x8229f0b   | _ZN12vehicleModel14updHeaderModelEP5QListIjE  
0x822be7e | 0x822bf64   | _ZN14vehTableWidget19updVehicleTabLayoutEib  
0x822c668 | 0x822c8e7   | _ZN14vehTableWidget13setupVehTableEib  
0x82845f8 | 0x82846fc   | _ZN14vehTableWidget11qt_metacallEN11QMetaObject4CallEiPPv

...程序外的函数调用

0x8060e86 | 0x80612ce | main  

_____________________|____________________|address outside of program: 4804252  

0x8060a70 | 0x8060a91 | _start  

_____________________|____________________|address outside of program: 3218418744  

0x808df02 | 0x808df13 | _ZN12QMutexLockerD1Ev    

_____________________|____________________|address outside of program: 3218420336  
_____________________|____________________|address outside of program: 152429104  
_____________________|____________________|address outside of program: 3218420552  

0x8208fa6 | 0x820acd0 | _ZN19datalog_render_area9prepStripEh  

_____________________|____________________|address outside of program: 3218420336  
_____________________|____________________|address outside of program: 3218420500  

最佳答案

很可能,您在堆栈中看到了垃圾。为了获得准确的堆栈跟踪,调试器需要帧指针(在 x86 上通常被省略以保存寄存器)或调试信息。如果没有这些信息,它会尝试猜测 - 它会在堆栈中扫描看起来有点像代码地址的指针,并尽力将它们与它们所属的函数相匹配。

正如其他人所提到的,静态初始化会导致代码在 main 之前执行,但是这段代码在 main 运行时已经返回,所以他们没有业务在真正的堆栈跟踪上。我会说,最有可能的是,_start 之后的所有内容都是垃圾数据,可以安全地忽略。

关于c++ - 在回溯中 _start 和 main 之前看到的函数调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6755491/

相关文章:

C++ 字符串前向声明不明确

c++ - 使用 QGLShaderProgram 将自定义类型(结构)统一从 Qt 传递到 GLSL

c++ - D3D12CreateDevice 抛出 _com_error

c++ - 获取 QCheckBox 在 QTableWidget 中的单元格位置

c++ - CMake:创建二进制 foo + 库 libfoo?

linux - 将输出重定向到文件 shell 脚本

linux - 在 bash 中确定批处理作业的 PID

linux - 如何在内核启动时添加 printk 函数

c++ - QListWidget 中的项目在重新排序后变得不可见

c++ - QPushButton setIcon 不工作