美文网首页
pdb--Dbug调试

pdb--Dbug调试

作者: 錦魚 | 来源:发表于2018-10-15 08:35 被阅读0次

执行时调试

程序启动,停止在第一行等待单步调试。

python -m pdb some.py

交互调试进入python或ipython解释器

  import pdb
  pdb.run('testfun(args)') #此时会打开pdb调试,注意:先使用s跳转到这个testfun函数中,然后就可以使用l看到代码了

程序里埋点当程序执行到pdb.set_trace() 位置时停下来调试

代码上下文

  ...
  import pdb
  pdb.set_trace()
  ...

日志调试print大法好使用pdb调试的5个demodemo 1

import pdb
a = "aaa"
pdb.set_trace()
b = "bbb"
c = "ccc"
final = a + b + c
print final

调试方法

《1 显示代码》
# l---->能够显示当前调试过程中的代码,其实l表示list列出的意思
  #如下,途中,-> 指向的地方表示要将要执行的位置
  # 2      a = "aaa"
  # 3      pdb.set_trace()
  # 4      b = "bbb"
  # 5      c = "ccc"
  # 6      pdb.set_trace()
  # 7  ->    final = a + b + c
  # 8      print final

# 《2 执行下一行代码》
# n---->能够向下执行一行代码,然后停止运行等待继续调试 n表示next的意思

# 《3 查看变量的值》
# p---->能够查看变量的值,p表示prit打印输出的意思
    #例如:
    # p name 表示查看变量name的值demo 2

import pdb
a = "aaa"
pdb.set_trace()
b = "bbb"
c = "ccc"
pdb.set_trace()
final = a + b + c
print final

《4 将程序继续运行》

c----->让程序继续向下执行,与n的区别是n只会执行下面的一行代码,而c会像python xxxx.py一样 继续执行不会停止;c表示continue的意思

《5 set_trace()》

如果程序中有多个set_trace(),那么能够让程序在使用c的时候停留在下一个set_trace()位置处demo 3
#coding=utf-8
import pdb

def combine(s1,s2):
    s3 = s1 + s2 + s1
    s3 = '"' + s3 +'"'
    return s3

a = "aaa"
pdb.set_trace()
b = "bbb"
c = "ccc"
final = combine(a,b)
print final

《6 设置断点》

b---->设置断点,即当使用c的时候,c可以在遇到set_trace()的时候停止,也可以在遇到标记有断点的地方停止;b表示break的意思
#例如:
#b 11 在第11行设置断点,注意这个11可以使用l来得到
# (Pdb) l
#   4          s3 = s1 + s2 + s1
#   5          s3 = '"' + s3 +'"'
#   6          return s3
#   7      a = "aaa"
#   8      pdb.set_trace()
#   9  ->    b = "bbb"
#  10      c = "ccc"
#  11      final = combine(a,b)
#  12      print final
# [EOF]
# (Pdb) b 11
# Breakpoint 1 at /Users/wangmingdong/Desktop/test3.py:11
# (Pdb) c
# > /Users/wangmingdong/Desktop/test3.py(11)<module>()
# -> final = combine(a,b)
# (Pdb) l
#   6          return s3
#   7      a = "aaa"
#   8      pdb.set_trace()
#   9      b = "bbb"
#  10      c = "ccc"
#  11 B->    final = combine(a,b)
#  12      print final

《7 进入函数继续调试》

s---->进入函数里面继续调试,如果使用n表示把一个函数的调用当做一条语句执行过去,而使用s的话,会进入到这个函数 并且停止

#例如
# (Pdb) l
#   6          return s3
#   7      a = "aaa"
#   8      pdb.set_trace()
#   9      b = "bbb"
#  10      c = "ccc"
#  11 B->    final = combine(a,b)
#  12      print final
# [EOF]
# (Pdb) s
# --Call--
# > /Users/wangmingdong/Desktop/test3.py(3)combine()
# -> def combine(s1,s2):
# (Pdb) l
#   1      import pdb
#   2
#   3  ->    def combine(s1,s2):
#   4          s3 = s1 + s2 + s1
#   5          s3 = '"' + s3 +'"'
#   6          return s3
#   7      a = "aaa"
#   8      pdb.set_trace()
#   9      b = "bbb"
#  10      c = "ccc"
#  11 B    final = combine(a,b)
# (Pdb)

《8 查看传递到函数中的变量》

a---->调用一个函数时,可以查看传递到这个函数中的所有的参数;a表示arg的意思

#例如:
# (Pdb) l
#   1      #coding=utf-8
#   2      import pdb
#   3
#   4  ->    def combine(s1,s2):
#   5          s3 = s1 + s2 + s1
#   6          s3 = '"' + s3 +'"'
#   7          return s3
#   8
#   9      a = "aaa"
#  10      pdb.set_trace()
#  11      b = "bbb"
# (Pdb) a
# s1 = aaa
# s2 = bbb

《9 执行到函数的最后一步》

r----->如果在函数中不想一步步的调试了,只是想到这个函数的最后一条语句那个位置,比如return语句,那么就可以使用r;r表示return的意思demo 4
In [1]: def pdb_test(arg):
   ...:     for i in range(arg):
   ...:         print(i)
   ...:     return arg
   ...:

In [2]: #在python交互模式中,如果想要调试这个函数,那么可以

In [3]: #采用,pdb.run的方式,如下:

In [4]: import pdb

In [5]: pdb.run("pdb_test(10)")
> <string>(1)<module>()
(Pdb) s
--Call--
> <ipython-input-1-ef4d08b8cc81>(1)pdb_test()
-> def pdb_test(arg):

(Pdb) l
  1  ->    def pdb_test(arg):
  2          for i in range(arg):
  3              print(i)
  4          return arg
[EOF]
(Pdb) n
> <ipython-input-1-ef4d08b8cc81>(2)pdb_test()
-> for i in range(arg):
(Pdb) l
  1      def pdb_test(arg):
  2  ->        for i in range(arg):
  3              print(i)
  4          return arg
[EOF]
(Pdb) n
> <ipython-input-1-ef4d08b8cc81>(3)pdb_test()
-> print(i)
(Pdb)
0
> <ipython-input-1-ef4d08b8cc81>(2)pdb_test()
-> for i in range(arg):
(Pdb)
> <ipython-input-1-ef4d08b8cc81>(3)pdb_test()
-> print(i)
(Pdb)
1
> <ipython-input-1-ef4d08b8cc81>(2)pdb_test()
-> for i in range(arg):
(Pdb)demo 5 运行过程中使用pdb修改变量的值

In [7]: pdb.run("pdb_test(1)")
> <string>(1)<module>()
(Pdb) s
--Call--
> <ipython-input-1-ef4d08b8cc81>(1)pdb_test()
-> def pdb_test(arg):
(Pdb) a
arg = 1
(Pdb) l
  1  ->    def pdb_test(arg):
  2          for i in range(arg):
  3              print(i)
  4          return arg
[EOF]
(Pdb) !arg = 100  #!!!这里是修改变量的方法
(Pdb) n
> <ipython-input-1-ef4d08b8cc81>(2)pdb_test()
-> for i in range(arg):
(Pdb) l
  1      def pdb_test(arg):
  2  ->        for i in range(arg):
  3              print(i)
  4          return arg
[EOF]
(Pdb) p arg
100
(Pdb)练一练:请使用所学的pdb调试技巧对其进行调试出bug

#coding=utf-8
import pdb

def add3Nums(a1,a2,a3):
    result = a1+a2+a3
    return result


def get3NumsAvarage(s1,s2):
    s3 = s1 + s2 + s1
    result = 0
    result = add3Nums(s1,s2,s3)/3

if __name__ == '__main__':

    a = 11
    # pdb.set_trace()
    b = 12
    final = get3NumsAvarage(a,b)
    print final
  • pdb 调试有个明显的缺陷就是对于多线程,远程调试等支持得不够好,同时没有较为直观的界面显示,不太适合大型的 python 项目。而在较大的 python 项目中,这些调试需求比较常见,因此需要使用更为高级的调试工具。
  • 缺点:多线程支持不好,没有直观界面显示,

相关文章

  • pdb--Dbug调试

    执行时调试 程序启动,停止在第一行等待单步调试。 python -m pdb some.py 交互调试进入pyth...

  • Flutter 调试方式

    在 Flutter 里有几种调试方式。 断点调试。 debugger 调试。 rendering 调试。 日志调试...

  • vscode使用指南(代码调试)

    代码调试 vscode 原生支持nodejs的调试,其他语言需要安装拓展支持调试 代码调试界面 调试界面 调试配置...

  • HBuilder Android真机调试

    关于调试 难者不会,会者不难。对于调试,这句话尤其合适。无论是前端调试、Java调试、PHP调试、Python调试...

  • iOS 调试

    iOS调试 - NSLog iOS调试 - 断点 iOS调试 - LLDB iOS调试 - EXC_BAD_ACC...

  • 2018-08-15 Windows调试和内核

    Windows调试 软件调试分类。按目标代码的执行模式:内核态调试,用户态调试;按调试器与调试目标的相对位置:本机...

  • WWDC2015 高级调试技巧笔记

    我将为大家介绍以下三个方面的调试技巧 视图调试高级断点调试Address Sanitizer 视图调试 视图调试的...

  • Android Studio调试

    参考 断点调试 实用调试 总结:断点调试有step into step out 等 实用调试:条件断点、日志断点、...

  • 调试手段

    本地调试 远程调试

  • linux编程入门(七)-使用gdb调试程序

    程序开发离不开调试,可以断点调试,也可以打log调试,linux下断点调试c,c++程序用gdb。 断点调试虽然很...

网友评论

      本文标题:pdb--Dbug调试

      本文链接:https://www.haomeiwen.com/subject/mdmxzftx.html