日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
人生苦短我用Python[0x02]如何調(diào)試Python程序

今天為大家介紹如何調(diào)試Python程序。

0. 安裝基礎(chǔ)包

以Ubuntu 16.04 為例子

sudo apt-get install gdb python2.7-dbg

1. 如何調(diào)試python代碼

 我們會(huì)使用python自帶的pdb模塊來(lái)調(diào)試代碼,在熟悉pdb功能前,先寫(xiě)一個(gè)測(cè)試代碼 1.py

 
 
 
 
  1. a = 1 
  2. b = 1 
  3. c = a + b 
  4. print c 

使用pdb模塊靜態(tài)調(diào)試python代碼,執(zhí)行pdb 1.py返回如下

輸入 h 返回pdb的命令列表,里面包含了所有命令及其簡(jiǎn)寫(xiě),比如h是代表help

查看代碼內(nèi)容命令是list,簡(jiǎn)寫(xiě)是l,其中l(wèi)ist命令的參數(shù)格式是 list [first, last],默認(rèn)情況下list會(huì)輸出文件的前11行代碼,比如我們的文件代碼只有幾行,再list的時(shí)候提示EOF文件已經(jīng)結(jié)束了,如果再想看代碼的話,可以用list 0來(lái)從開(kāi)頭看起。

 我們現(xiàn)在要測(cè)試斷點(diǎn)功能,b 3,代表我要在代碼第3行下一個(gè)斷點(diǎn),r是代表run把程序跑起來(lái),然后程序會(huì)停留在我斷點(diǎn)的位置,這個(gè)時(shí)候我可以用p把a(bǔ)和b的變量值內(nèi)容打印出來(lái),然后我再n代表next繼續(xù)運(yùn)行,然后我再打印c的變量值。

2. 如何已經(jīng)在運(yùn)行的python程序

上面講了如何調(diào)試python程序的一些基礎(chǔ)知識(shí),接下來(lái)我們要介紹的是如何調(diào)試一個(gè)已經(jīng)在運(yùn)行的python程序,比如在實(shí)際工作中,寫(xiě)了一個(gè)python程序在運(yùn)行了,然后發(fā)現(xiàn)程序有異?;蛘邟熳o(wú)法響應(yīng)業(yè)務(wù)了,這個(gè)時(shí)候可以用gdb attach這個(gè)進(jìn)程,然后查看調(diào)用棧信息,從而可以獲知目前程序掛載那個(gè)地方。

 先寫(xiě)一個(gè)測(cè)試代碼 2.py,我們用time.sleep函數(shù)來(lái)模擬一個(gè)被掛起的程序

 
 
 
 
  1. import time 
  2. time.sleep(10000) 

 把程序運(yùn)行起來(lái) python 2.py 先查看已經(jīng)運(yùn)行起來(lái)2.py的pid,然后再執(zhí)行命令

 
 
 
 
  1. gdb python pid 
  2. #查看當(dāng)前堆棧信息 
  3. py-bt 
  4. #我們可以看到,程序目前掛在time.sleep(10000)這個(gè)調(diào)用上 

【本文是專(zhuān)欄機(jī)構(gòu)作者“睿江云EflyCloud”的原創(chuàng)文章,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

戳這里,看該作者更多好文

【責(zé)任編輯:xinxiaoliang TEL:(010)68476606】 


網(wǎng)頁(yè)標(biāo)題:人生苦短我用Python[0x02]如何調(diào)試Python程序
網(wǎng)站網(wǎng)址:http://www.dlmjj.cn/article/djehhsp.html