breakpoint()是Python3.7中新引入的一个内置函数,其主要作用是在开发Python程序时,在使用breakpoint()函数的地方进入程序调试器,以便跟踪观察程序的运行情况。
调试Python程序是一件令人头疼的事情,在使用Python 3.7之前,开发者为调试程序不得不首先引入pdb包,然后调用pdb.set_trace()函数来跟踪调试程序。但如果你准备使用其它调试器,如web-pdb,你就不得不把与PDB模块有关的代码移除掉,然后添加web_pdb.set_trace()方法。这使得为调试Python程序,不得不花费更大的精力和开销,使得Python程序难以维护和调试。
Python3.7引入的breakpoint()方法可以使我们编写松耦合调试代码。该函数自动调用sys.breakpointhook()函数,直接传递相关参数。默认情况下,sys.breakpointhook()函数内部调用pdb.set_trace()方法而不需要参数。这种情况下下,该函数自动引入pdb包,而无需用户显示的引入pdb包。但用户可以将sys.breakpointhook()设置为其它函数,breakpoint()函数将自动调用用户设置的函数,而进入用户所选择的调试器。
breakpoint(*args, **kws)
参数
*args:位置参数,不定长参数
**kws:关键字参数,不定长参数。
该函数将在当前位置进入到程序到程序调试器,而无需返回值。
该函数参数使用错误可能会引发TypeError错误。
下面例子展示 breakpoint()函数使用方法。
lst = []
for i in range(10):
lst.append(i)
if i == 5:
#开始跟踪调试
breakpoint()
print(lst)
上面的例子演示的是向列表lst中追加数据。当循环计数i为5时,执行breakpoint()函数进入到调试器中。
整个调试过程如下图所示:
进入pdb调试过程后,首先键入 'p lst',将lst的当前值输出来,命令符'p'的作用是输出某个对象(如变量lst)的值。然后键入命令'n'然后回车进入到下一个代码执行中。命令符'c'的作用是继续执行程序直到遇到下一个breakpoint()。
因为该程序只有当i == 5时才会遇到breakpoint(),所以键入'c'后程序直接执行到最后,并输出了lst中的全部元素。
这篇文章介绍了breakpoint()函数的使用方法。如果在编写程序中遇到无法观察到的问题时,在可能出现问题的地方使用breakpoint()函数,使程序运行时进入到pdb程序调试模块以跟踪程序的执行情况。关于Python的调试问题,本站将在今后的文章中继续给予详细的介绍。
新闻热点
疑难解答