2

我正在查看使用 GDB 的实时 python 进程并看到以下帧:

...
#5  call_function (oparg=<optimized out>, pp_stack=0x7fffb1b2ffa0) at Python/ceval.c:4084
#6  PyEval_EvalFrameEx (f=f@entry=0x1a03850, throwflag=throwflag@entry=0) at Python/ceval.c:2679
...

我很困惑call_function从哪里来。它似乎不是 python 可执行文件或二进制文件中的符号:

~  ᐅ objdump -x /usr/lib/libpython3.3m.so.1.0 | grep call_function
000000000005f0e0 l     F .text  0000000000000094              call_function_tail

如果它不是一个已知的符号,GDB 是如何知道它的……它到底是什么(当然除了它是一个正常的函数)?

4

1 回答 1

1

它在 Python 解释器的源代码中,您的 gdb 说明在哪里,但您可以在此处查看它,尽管在不同的行:3971。

该函数的定义是:

static PyObject * call_function(PyObject ***pp_stack, int oparg);

由于它是一个static函数,它具有内部链接,因此它在其编译单元之外是不可见的,更不用说它的动态库(.so 文件)了。

调试器知道它,因为它以某种方式可以访问正在运行的代码的调试信息。

于 2013-09-29T21:37:45.303 回答