windbg条件断点

假设源文件a.cpp如下所示:
  1. void main()
  2. {
  3.     int sum = 0;
  4.     for (int i = 0; i<10; i++)
  5.     {
  6.         sum += i;
  7.     }
  8. }
 要在第6行下一个条件断点,当i>=6的时候断点生效,则可以用如下命令:
  1. bp `a.cpp:6` ".if(poi(i)<6) {gc} .else {}"
解释如下:
  1. .if, .else是windbg条件判定命令,格式为.if(条件) {表达式1} .else {表达式2}。表达式里可以包含多条语句。
  2. gc 是go from conditional point的缩写,就是从该条件断点开始执行程序
  3. poi是masm里面的取值命令。在windbg的表达式中,默认采用了masm汇编的语法,汇编语言中一个变量代表了存储该标量的地址,所以要得到该变量的内容,要进行取值操作,类似c语言中的*p。
  4. bp `a.cpp:6`是在源文件a.cpp的第六行下断电。
用windbg,一开始的感觉是很不方便,因为以前用的ide,Eclipse,visual studio等等debug的经历都很赞。windbg在使用方便性上确实比不上IDE里面的debugger。也难怪,windbg是一个debugger内核加上一个UI。这个UI据说就是做debugger的dev写出来的。想象一下整天做内核的同学去写UI,能做成这样也已经很不错了。

不过话说回来,UI不强,但是功能的确是很强。一些其他debugger里面的功能,windbg基本上是只多不少。就拿条件断点来说,.if/.else其实也只是一个windbg命令,完全可以用不同的命令替代之,已达到不同的目的。

举例来说,试想希望有条件的输出一些log信息,但是不希望被调试的程序终端执行。可以用这样的命令:
  1. bp `a.cpp:6` "dt i; g"
dt用来log,g使程序继续执行。

你可能感兴趣的:(windbg条件断点)