非终止python程序的cProfile

问题描述

我有一个用于调试的非终止 python 程序

import faulthandler
faulthandler.dump_traceback_later(480,exit=True)
call_very_complicated_python_code()

我想对其进行分析以更好地了解哪些部分卡住了:

$ python -m cProfile -o program.prof my_program.py my_input.txt
  • faulhandler 机制是否会干扰分析?
  • program.prof 并非总是生成的。
  • 有什么办法可以解决这个问题吗?

解决方法

我没有使用过 faulthandler,但无论如何听起来都是错误的工具。如果您的代码永无止境或错误,那么回溯从何而来?

分析用于衡量代码的速度。如果你想理解代码,我建议你用 pdb 之类的东西调试它。

在模块顶部添加 import pdb

在您想停下来检查的区域添加:pdb.set_trace()

也许您有一些从未竞争过的递归或循环?