Windbg断点 dt命令

bp 在某个地址下断点
   bp 0x7783FEB
   bp MyApp!SomeFunction
   对于后者,Windbg会找到MyApp!SomeFunction对应的地址并设置断点。使用bp的问题:1、代码修改之后,函数地址改变,该断点仍然保持在相同位置,不一定继续有效;2、Windbg不会把bp断点保存工作空间中,所以,我比较喜欢用bu 命令。

bu 针对某个符号下断点。
   bu MyApp!SomeFunction
   在代码被修改之后,该断点可以随着函数地址改变而自动更新到最新位置。而且bu 断点会保存在WinDbg工作空间中,下次启动 Windbg的时候该断点会自动设置上去。
另外,模块没有被加载时,bp 断点会失败(因为函数地址不存在),而bu 断点则可以成功。 新版的Windbg中bp失败后会自动被转成bu。

bm 针对符号下断点,支持匹配表达式。
   bu MyApp!MyClass::*     // 把MyClass 所有的成员函数都下断点
   bu user32!CreateWindow* // 把所有以CreateWindow开头的函数都下断点
   以上三个命令是对代码下断点,我们还可以对数据下断点。
ba 针对数据下断点,该断点在指定内存被访问时触发。
   命令格式:ba Access Size [地址]
             Access 是访问的方式,比如 e(执行),r(读/写),w(写)
             Size 是监控访问的位置的大小,以字节为单位。 值为 1、2或4,还可以是 8(64位机)。
             对内存0x0483DFE进行写操作的时候下断点,可以用命令 ba w4 0x0483DFE

bl 列出所有断点
bc 清除断点
bd 禁用断点
be 启动被bd 命令经用的断点

 

 

Windbg提供dt命令来显示符号类型信息(Dump symbolic Type information),有以下3种用法:
1、dt [ModuleName]!TypeName,若省略模块名,则自动查找所有已加载的模块,如“dt ntdll!*”显示ntdll里的所有类型信息。
   其中,-b开关指定递归显示所有子类型信息,-r加数字指定递归显示的深度,如-r0表示不显示子类型信息。
   若不想显示全部字段,可以使用开关-ny附加字段过滤搜索信息,如dt _TEB -ny LastError。
2、第2种用法是在上一种用法之后加上内存地址,按照指定的内存地址的内容来显示具体类型的变量。
3、第3种用法是显示类型的实例,如全局变量、静态变量和函数。同样可以枚举函数符号,
   此时同x命令的功能相似,如dt dbgee!*wmain*,若是指定的函数,则会显示该函数的参数取值和返回值类型。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windbg(Windows Debugger)是微软官方提供的一款强大的调试工具,主要用于分析和调试Windows系统下的应用程序。设置断点是调试过程中的重要步骤,它允许你在程序执行到特定行或代码块时暂停,以便查看和修改变量值、检查调用堆栈等。 以下是设置断点的基本步骤: 1. **打开Windbg**:首先,你需要打开Windbg,可以通过“开始”菜单搜索或直接运行`cdb.exe`(命令行版)或`windbg.exe`(图形界面版)。 2. **加载目标模块**:如果你知道要调试的应用程序的进程ID(PID)或进程名,使用`!process`命令加载它。例如:`.reload /f <进程名>` 或 `~pid <进程ID>`。 3. **找到源代码位置**:在加载了目标模块后,使用`lm`(list modules)命令查看模块信息,然后找到你想要设置断点的源代码行号,通常文件路径会出现在模块信息中。 4. **设置断点**:使用`bp`命令加上模块路径和行号,例如:`bp <模块路径>\function_name + line_number`。你也可以使用符号文件(.pdb)的相对路径来设置断点,如:`bp !function_name`。 5. **断点选项**:如果需要,你可以添加条件、步进等选项,例如设置只在满足某个条件时触发断点,用`b`命令后跟条件表达式,如 `b function_name(line_number) condition`。 6. **启动调试**:最后,启动你要调试的进程,Windbg会在设置的断点处停止程序执行。 相关问题: 1. Windbg除了断点还有哪些调试功能? 2. 如何在Windbg中单步执行代码? 3. 如何查看断点列表和管理已设置的断点

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值