自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

人生苦短 我用Python [0x02] 如何調(diào)試Python程序

開發(fā) 開發(fā)工具
今天為大家介紹如何調(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模塊來調(diào)試代碼,在熟悉pdb功能前,先寫一個(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)寫,比如h是代表help

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

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

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

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

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

  1. import time 
  2. time.sleep(10000

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

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

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

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

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

責(zé)任編輯:xinxiaoliang 來源: 51CTO專欄
相關(guān)推薦

2017-03-23 10:42:05

Pythonjava開發(fā)

2017-06-05 08:55:27

Python起源應(yīng)用

2017-06-09 08:16:50

python動(dòng)態(tài)模塊

2017-06-20 15:02:48

ChromeWebKit內(nèi)核

2017-03-07 10:07:25

PythonIDE

2018-04-05 22:42:43

2020-12-15 15:21:41

C++JavaPython

2014-09-26 09:29:12

Python

2022-10-21 15:23:41

GN入門示例鴻蒙

2020-11-03 11:18:35

Go語(yǔ)言GoLang編程語(yǔ)言

2019-11-18 14:20:33

Python 開發(fā)編程語(yǔ)言

2021-03-23 11:02:27

ManjaroLinux

2016-11-04 13:30:07

Python運(yùn)維工程師

2018-04-16 09:31:17

2020-04-07 11:23:20

Python 開發(fā)編程語(yǔ)言

2021-09-18 12:05:59

Python 開發(fā)編程語(yǔ)言

2020-11-09 14:26:30

GitHub 技術(shù)開源

2018-03-22 11:00:45

PythonRSS

2020-06-23 09:48:09

Python開發(fā)內(nèi)存

2018-08-09 18:27:03

編程語(yǔ)言JavaPython
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)