我在 SunOS 5.10 上使用编译了我的库(特别是protbuf-2.3.0) 。-g -O0
make 日志中的示例行是这样的:
/bin/bash ../libtool --tag=CXX --mode=compile g++ -DHAVE_CONFIG_H -I. -I.. -D_REENTRANT -pthreads -Wall -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare -g -O0 -MT text_format.lo -MD -MP -MF .deps/text_format.Tpo -c -o text_format.lo `test -f 'google/protobuf/text_format.cc' || echo './'`google/protobuf/text_format.cc
libtool: compile: g++ -DHAVE_CONFIG_H -I. -I.. -D_REENTRANT -pthreads -Wall -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare -g -O0 -MT text_format.lo -MD -MP -MF .deps/text_format.Tpo -c google/protobuf/text_format.cc -fPIC -DPIC -o .libs/text_format.o
然后,我使用以下步骤附加了我的 gdb:
- 运行我的应用程序(在这种情况下,我的 Web 服务器启动了一个 Java Web 应用程序,该应用程序在启动期间通过 jni 使用库)。
gdb -p XXX
我通过(其中 XXX 是我从中获得的 pid )将我的 gdb 附加到该进程ps
。- 然后我使用
file libprotobuf.so
gdb 提示符从 gdb 加载我的库。
但我看不到我的函数名称bt
。我的 GDB 回溯命令显示如下:
(gdb) bt
#0 0xf8f98914 in ?? ()
#1 0xf8f98830 in ?? ()
Backtrace stopped: previous frame identical to this frame (corrupt stack?)
我也试过只做 #1 & #2,只做 #1 & #3 和 #1 & gdb libprotobuf.so -p XXX
。
除此之外,我还尝试在调试模式下运行我的 jvm 并在命令上添加一个断点System.loadLibrary(..)
,然后在跳过该命令之后,我再次执行 gdb 附加过程......但仍然没有。
但是,我可以在给定函数名称的情况下放置断点,并通过list
. 但是话又说回来,我可以放置断点,但它们不会在这些函数名称上停止(我知道它去了那个函数,因为它在每次 jvm 崩溃后的 jvm hs_err_pid 报告中)。
有什么想法没有显示我的函数名称吗?