gpt4 book ai didi

java - Backtrace 中缺少 gdb 符号?

转载 作者:行者123 更新时间:2023-12-01 11:28:36 26 4
gpt4 key购买 nike

我正在运行此测试,因为我想查看程序的堆栈跟踪。下面是我的程序:

 public class NanoTime {
public static void main (String[] args) {
long StartTime = System.nanoTime();
StringBuffer buffer = new StringBuffer();
for(int i=0; i<1000; i++) {
buffer.append("a"); }
long EndTime = System.nanoTime();
long totalTime = EndTime-StartTime;
System.out.println("Total time of calculation ="+ totalTime);
}

}

现在我使用 OpenJDK,其调试级别设置为 Slowdebug,另一个设置为 fastdebug。我得到这个输出:

[New Thread 0x7ffff7fd3700 (LWP 22532)]

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff7fd3700 (LWP 22532)]0x00007fffe10002b4 in ?? ()
(gdb) bt
#0 0x00007fffe10002b4 in ?? ()
#1 0x0000000000000202 in ?? ()
#2 0x00007fffe1000160 in ?? ()
#3 0x00007ffff66bd1a9 in execute_internal_vm_tests () at /home/bionix/Openjdk8/hotspot/src/share/vm/prims/jni.cpp:5128
#4 0x00007ffff7fd2550 in ?? ()
#5 0x00007ffff6b08bf8 in VM_Version::get_cpu_info_wrapper () at /home/bionix/Openjdk8/hotspot/src/cpu/x86/vm/vm_version_x86.cpp:395
Backtrace stopped: previous frame inner to this frame (corrupt stack?)

我对那里的问号感到困惑,因为我期望 native 方法名称。

注意:我什至禁用了 JIT 编译器:gdb --args java -Xint Test

最佳答案

在普通代码中,gdb 依赖调试信息(在较小程度上依赖“链接器”符号)来查找展开时的函数名称。调试信息在各种标准中都有描述,DWARF 是当前适用于 Linux 的最佳标准。编译器发出调试信息,然后由 gdb 读取。

对于像 OpenJDK 这样的即时编译器,没有一致同意的解决方案来发出调试信息以供调试器读取。因此,正如您所发现的,gdb 通常不知道发生了什么。

事实上,正如您从跟踪中看到的那样,gdb 甚至无法真正展开整个堆栈。这就是这个意思:

Backtrace stopped: previous frame inner to this frame (corrupt stack?)

现代编译器和 ABI 往往也需要一些额外的调试信息来展开 - 而且,对于 JIT 编译如何工作,还没有达成一致。当此信息不可用时,GDB 使用一些启发式方法来尝试放松,但正如您所看到的,它们有时会失败。

所以,这是坏消息。

好消息是 gdb 提供了一些为 JIT 编写展开程序和调试信息读取器的方法。而且,有人正在为 OpenJDK 做这方面的工作。我无法快速找到来源,但我确实找到了 this thread这稍微解释了一点。

关于java - Backtrace 中缺少 gdb 符号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30617733/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com