谷歌大佬又一開源神作,Python 調(diào)試?yán)?

來自量子位
寫代碼時(shí)提筆千行,debug 時(shí)卻低效抓狂……
幾乎每個(gè)編程者都逃不了這樣的糾結(jié)。
通過編譯器一行行地去找 bug,太浪費(fèi)時(shí)間。

所以,一位清華校友、谷歌工程師?laike9m,便開發(fā)了一個(gè)強(qiáng)大的 Python 調(diào)試工具?Cyberbrain:
能夠詳細(xì)記錄項(xiàng)目數(shù)據(jù)流、變量、狀態(tài)等等關(guān)鍵信息。
并且,結(jié)果還會(huì)以直觀簡(jiǎn)潔的可視化圖片呈現(xiàn)。
有了這個(gè)神器,今后 debug 也會(huì)和寫代碼一樣流暢高效。
“賽博大腦” 幫你 debug
平常你的程序中出現(xiàn) bug 時(shí)會(huì)怎么辦?
最常規(guī)的辦法是用調(diào)試器,但是你能記住程序中每個(gè)步驟發(fā)生什么了嗎?
這就是傳統(tǒng)方法的缺點(diǎn):調(diào)試信息無法持久化,要靠程序員去記住它們。
這款名叫?Cyberbrain(賽博大腦)的強(qiáng)大的工具,最亮眼的功能,是回溯代碼中的變量更改歷史,查看程序執(zhí)行的狀態(tài)。

所以,在你調(diào)試程序或 debug 時(shí),不需要費(fèi)幾個(gè)小時(shí)用編譯器逐行執(zhí)行。
Cyberbrain 會(huì)清晰的告訴你流程中都發(fā)生過什么:

Cyberbrain 能顯示準(zhǔn)確的數(shù)據(jù)流,并保留程序的每個(gè)狀態(tài)。程序員不僅不需要記住任何內(nèi)容,甚至不需要逐步執(zhí)行程序,這可以節(jié)省大量調(diào)試時(shí)間。
比方說,你想找出為什么返回值是錯(cuò)誤的。通過看圖,就可以對(duì)導(dǎo)致返回值的原因有了一個(gè)大概的了解。
接下來,將鼠標(biāo)懸停在 “返回 “節(jié)點(diǎn)上,所有相關(guān)的值都顯示出來了,形成了一個(gè)從函數(shù)開始到結(jié)束的跟蹤路徑:

只要?jiǎng)觿?dòng)鼠標(biāo)就能找到問題,誰(shuí)還會(huì)去用麻煩的編譯器呢?
除了流程和變量跟蹤,賽博大腦還能對(duì)目標(biāo)進(jìn)行檢查。
如果現(xiàn)在有一個(gè)大列表,但它無法與圖匹配,如何使用工具來檢查它的值?
啟動(dòng)后,Cyberbrain 會(huì)自動(dòng)打開一個(gè) devtools 窗口。
當(dāng)你把鼠標(biāo)懸停在一個(gè)變量上時(shí),它的值就會(huì)被記錄在 devtools 控制臺(tái)中。
所以在這種情況下,雖然沒有足夠的空間在跟蹤圖中顯示整個(gè)列表,但你仍然可以從 devtools 中檢查它的值。

幾乎所有的 Python 調(diào)試器 (PyCharm、VS Code 等) 都會(huì)截?cái)鄥?shù),無法顯示一個(gè)大列表中的每個(gè)元素,但 Cyberbrain 不會(huì)這樣做,除非你明確告訴它。
最后,Cyberbrain 還能讓用戶在 debug 的同時(shí),設(shè)置循環(huán)計(jì)數(shù)器。

如何安裝使用
Cyberbrain 由一個(gè) Python 庫(kù)和各種編輯器 / IDE 集成組成。目前它支持 VS Code 和 Gitpod。
安裝只需要通過一句話指令:
pip install Cyberbraincode —install-extension laike9m.Cyberbrain
同時(shí),作者還提供了在線版的 Cyberbrain,可以直接試用:
https://gitpod.io/#snapshot/91475a9d-4ccf-420a-b0ee-11db084ce689
在使用過程中,假如你想追蹤一個(gè)函數(shù) “foo”,可以使用?@trace?指令實(shí)現(xiàn):
from Cyberbrain import trace# As of now, you can only have one @trace decorator in the whole program.# We may change this in version 2.0, see https://github.com/laike9m/Cyberbrain/discussions/73@trace # Disable tracing with `@trace(disabled=True)`def?foo():
Cyberbrain 可以保持你的工作流程不變。運(yùn)行一個(gè)程序(從 vscode 或命令行,都可以),一個(gè)新的面板將被打開,程序執(zhí)行情況全部以可視化展示:

使用 Cyberbrain,還有幾點(diǎn)需要注意。
首先是可能會(huì)與其他調(diào)試器發(fā)生沖突。如果你設(shè)置了斷點(diǎn)并使用 VSC 的調(diào)試器,Cyberbrain 可能無法正常工作。一般來說,首選 “不調(diào)試運(yùn)行”。
而當(dāng)你的程序中有多個(gè)裝飾器(decorator)時(shí),應(yīng)該將 @trace 設(shè)置為最底層的那個(gè)。
此外,目前 Cyberbrain 還不支持多線程代碼。
作者介紹
作者?laike9m,谷歌軟件工程師,目前全職開發(fā) Cyberbrain 工具。
laike9m 是清華校友,在博客中自述曾擔(dān)任清華大學(xué)推理協(xié)會(huì)會(huì)長(zhǎng)。此外還是重度二次元愛好者。
除了 Cyberbrain,他還組織了一檔播客節(jié)目,名字叫捕蛇者說,Pythonhunter。
Cyberbrain 項(xiàng)目地址:
https://github.com/laike9m/Cyberbrain
laike9m 主頁(yè):
https://laike9m.com/blog/
播客地址:
https://pythonhunter.org/
