我正在调试一个 python 模块,它另外导入模块。
[主.py]
import module1
def main():
param = 'A'
module1.func1(param)
if __name__ == '__main__':
main()
[模块1.py]
def func1(arg1):
print(arg1)
所以我希望得到的是
PROMPT> python -m pdb main.py
(pdb) <theCommand>
calling main()
(pdb) <theCommand>
calling module1.func1(param = 'A')
(pdb) <theCommand>
calling print(firstArg = 'A')
A
我记得这可以在 gdb 中为 debuggin c 源代码完成。可以这样做 pdb 吗?
EDIT1:步骤不起作用
-> import module1
(Pdb) s
--Call--
> <frozen importlib._bootstrap>(1559)_find_and_load()
(Pdb)
> <frozen importlib._bootstrap>(1561)_find_and_load()
(Pdb)
> <frozen importlib._bootstrap>(1562)_find_and_load()
(Pdb)
--Call--
> <frozen importlib._bootstrap>(266)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(270)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(271)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(272)_get_module_lock()
(Pdb)
KeyError: 'module1'
> <frozen importlib._bootstrap>(272)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(273)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(274)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(275)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(276)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(279)_get_module_lock()
(Pdb)
--Call--
> <frozen importlib._bootstrap>(181)__init__()
(Pdb)
> <frozen importlib._bootstrap>(182)__init__()
(Pdb)
> <frozen importlib._bootstrap>(183)__init__()
(Pdb)
> <frozen importlib._bootstrap>(184)__init__()
(Pdb)
> <frozen importlib._bootstrap>(185)__init__()
(Pdb)
> <frozen importlib._bootstrap>(186)__init__()
(Pdb)
> <frozen importlib._bootstrap>(187)__init__()
(Pdb)
--Return--
> <frozen importlib._bootstrap>(187)__init__()->None
(Pdb)
> <frozen importlib._bootstrap>(280)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(282)_get_module_lock()
(Pdb)
> <frozen importlib._bootstrap>(283)_get_module_lock()
(Pdb)
--Return--
> <frozen importlib._bootstrap>(283)_get_module_lock()->_ModuleLock('...39858433548816
(Pdb)
> <frozen importlib._bootstrap>(1564)_find_and_load()
(Pdb)
> <frozen importlib._bootstrap>(1565)_find_and_load()
(Pdb)
--Call--
> <frozen importlib._bootstrap>(201)acquire()
(Pdb)
> <frozen importlib._bootstrap>(207)acquire()
(Pdb)
> <frozen importlib._bootstrap>(208)acquire()
(Pdb)
> <frozen importlib._bootstrap>(209)acquire()
(Pdb)
> <frozen importlib._bootstrap>(210)acquire()
(Pdb)
> <frozen importlib._bootstrap>(211)acquire()
我不知道该怎么办。
编辑2:这就是我使用gdb在c中调试的方式。[main.c]
#include <stdlib.h>
void func2(char * str)
{
NULL;
}
int func1(int a)
{
int b = 0;
b = b + 1; // useless statement
func2("this is a string");
return a;
}
int main()
{
int a = 0 ;
return func1(a);
}
现在 gdb a.out
(gdb) break func1
Breakpoint 1 at 0x4004c5: file main.c, line 10.
(gdb) break func2
Breakpoint 2 at 0x4004b8: file main.c, line 6.
(gdb) break main
Breakpoint 3 at 0x4004e7: file main.c, line 19.
(gdb) run
Starting program: ./a.out
warning: no loadable sections found in added symbol-file system-supplied DSO at 0x7ffff7ffa000
warning: Could not load shared library symbols for linux-vdso.so.1.
Do you need "set solib-search-path" or "set sysroot"?
Breakpoint 3, main () at main.c:19
19 int a = 0 ;
(gdb) c
Continuing.
Breakpoint 1, func1 (a=0) at main.c:10
10 int b = 0;
(gdb)
Continuing.
Breakpoint 2, func2 (str=0x400584 "this is a string") at main.c:6
6 }
(gdb)
Continuing.
[Inferior 1 (process 29249) exited normally]
(gdb)
(ps。我有一段时间没有使用 gdb,所以我之前可能听起来很困惑。现在一切都好。)
现在我尝试对 pdb 做同样的事情。
> ./main.py(3)<module>()
-> import module1
(Pdb) n
> ./main.py(5)<module>()
-> def main():
(Pdb) break module1.
module1.__builtins__ module1.__doc__ module1.__initializing__ module1.__name__ module1.func1
module1.__cached__ module1.__file__ module1.__loader__ module1.__package__ module1.py:
(Pdb) break module1.func1
Breakpoint 1 at ./module1.py:3
(Pdb) c
> ./module1.py(4)func1()
-> print(arg1)
(Pdb) c
A
The program finished and will be restarted
> ./main.py(3)<module>()
-> import module1
(Pdb)
所以而不是
> ./module1.py(4)func1()
我希望看到这样的东西
> ./module1.py(4)func1(arg1 = 'A')
谢谢。