Python 調試線程應用程序
在本章中,我們將學習如何調試線程應用程序。我們還將了解調試的重要性。
什么是調試?
在計算機編程中,調試是從計算機程序中查找和刪除錯誤,錯誤和異常的過程。一旦代碼被編寫就開始該過程,并且隨著代碼與其他編程單元組合以形成軟件產品,該過程在連續階段中繼續。調試是軟件測試過程的一部分,是整個軟件開發生命周期中不可或缺的一部分。
python調試器
python調試器或 pdb 是python標準庫的一部分。它是一個很好的后備工具,用于跟蹤難以發現的錯誤,并允許我們快速可靠地修復錯誤的代碼。以下是 pdp 調試器的兩個最重要的任務
- 它允許我們在運行時檢查變量的值。
- 我們也可以單步執行代碼并設置斷點。
我們可以通過以下兩種方式使用pdb
- 通過命令行; 這也稱為事后調試。
- 通過交互式運行pdb。
使用pdb
要使用python調試器,我們需要在我們想要進入調試器的位置使用以下代碼
import pdb; pdb.set_trace()
請考慮以下命令以通過命令行使用pdb。
- h(help)
- d(down)
- u(up)
- b(break)
- cl(clear)
- l(list))
- n(next))
- c(continue)
- s(step)
- r(return))
- b(break)
以下是python調試器的h(help)命令的演示 -
import pdb pdb.set_trace() --call-- >d:\programdata\lib\site-packages\ipython\core\displayhook.py(247)__call__() -> def __call__(self, result = none): (pdb) h documented commands (type help ): ======================================== eof c d h list q rv undisplay a cl debug help ll quit s unt alias clear disable ignore longlist r source until args commands display interact n restart step up b condition down j next return tbreak w break cont enable jump p retval u whatis bt continue exit l pp run unalias where miscellaneous help topics: ========================== exec pdb
例
在使用python調試器時,我們可以使用以下行在腳本中的任何位置設置斷點
import pdb; pdb.set_trace()
設置斷點后,我們可以正常運行腳本。腳本將執行到某一點; 直到設置了一條線。考慮以下示例,我們將在腳本中的不同位置使用上述行來運行腳本
import pdb; a = "aaa" pdb.set_trace() b = "bbb" c = "ccc" final = a + b + c print (final)
當運行上面的腳本時,它將執行程序直到a =“aaa”,我們可以在下面的輸出中檢查它。
輸出
--return-- > (3)()->none -> pdb.set_trace() (pdb) p a 'aaa' (pdb) p b *** nameerror: name 'b' is not defined (pdb) p c *** nameerror: name 'c' is not defined
在pdb中使用命令'p(print)'后,此腳本僅打印'aaa'。之后是錯誤,因為我們已將斷點設置為a =“aaa”。
同樣,我們可以通過更改斷點來運行腳本并查看輸出中的差異
import pdb a = "aaa" b = "bbb" c = "ccc" pdb.set_trace() final = a + b + c print (final)
輸出
--return-- > (5)()->none -> pdb.set_trace() (pdb) p a 'aaa' (pdb) p b 'bbb' (pdb) p c 'ccc' (pdb) p final *** nameerror: name 'final' is not defined (pdb) exit
在下面的腳本中,我們在程序的最后一行設置斷點
import pdb a = "aaa" b = "bbb" c = "ccc" final = a + b + c pdb.set_trace() print (final)
輸出如下
--return-- > (6)()->none -> pdb.set_trace() (pdb) p a 'aaa' (pdb) p b 'bbb' (pdb) p c 'ccc' (pdb) p final 'aaabbbccc' (pdb)