我目前正在尝试测试Vector类实现,并尝试使用GDB来查看错误发生的位置。
当我使用以下gcc -ggdb Vector.c TestVector.c
进行编译,然后在GDB中运行时,我得到以下输出(在崩溃并尝试打印堆栈跟踪之后):
| => gdb ./a.out
Reading symbols from ./a.out...Reading symbols from /Users/prog/Desktop/Generics/a.out.dSYM/Contents/Resources/DWARF/a.out...done.
done.
(gdb) r
Starting program: /Users/prog/Desktop/Generics/a.out
[New Thread 0x2703 of process 56984]
warning: unhandled dyld version (15)
Thread 2 received signal SIGSEGV, Segmentation fault.
0x00007fff65d97fe6 in ?? ()
(gdb) bt
#0 0x00007fff65d97fe6 in ?? ()
#1 0x00007ffeefbff640 in ?? ()
#2 0x00007fff65be4139 in ?? ()
#3 0x00007ffeefbff660 in ?? ()
#4 0x0000000000000000 in ?? ()
这对于确定错误归因于回溯的位置并没有特别帮助,只显示了我的函数执行的绝对存储位置。
我的问题是,为什么gdb没有给我准确的信息和lldb呢(尽管我没有改变两个调试会话之间的编译设置),我该如何解决这个问题?
如果有任何帮助,我使用Mac OS X,High Sierra作为我的操作系统。
答案 0 :(得分:4)
您正在使用的gdb无法识别dyld加载到进程中的共享库。请注意,在gdb输出的顶部,它表示"未处理的dyld版本(15)"。看起来您正在使用的gdb需要更新才能在macOS上正常运行。我现在不确定如何积极维护gdb的macOS端口。