条件断点在windbg中不起作用

问题描述 投票:0回答:1

我有以下C ++代码

int myvar=1;

void test1( int j)
{
    int b=j+1;
}


void main()
{

myvar=2;
    test1(50);      


    myvar=3;
    test1(100);     


    myvar=6;
    test1(200);     

}

我正在尝试设置一个断点,该断点在运行函数test1时如果myvar大于4则停止。

这是我的断点:

bp test!test1 ".if ( poi(myvar)>0n4) {} .else {gc} "

但是,每次执行test1时它都会停止...可执行文件称为test.exe,这是一个64位应用程序。任何建议将不胜感激。

windbg breakpoints
1个回答
0
投票

在断点处的一些调试可以揭示正在发生的事情:

 0 e Disable Clear  00007ff6`77e11410  [f:\projects\windbg_help\main.cpp @ 4]     0001 (0001)  0:**** windbg_help!test1 "?? myvar; r $t1=myvar; ?? @$t1; r $t2=poi(myvar); ?? @$t2;  .if (dwo(myvar) > 0n4) {.echo yes; gc} .else {.echo no; gc} "

我将t1临时寄存器设置为myvar,并将t2临时寄存器设置为myvar的内容,然后显示它们:

0:000> g
int 0n2
unsigned int64 0x00007ff6`77e1c000
unsigned int64 0xffffffff`00000002
no
int 0n3
unsigned int64 0x00007ff6`77e1c000
unsigned int64 0xffffffff`00000003
no
int 0n6
unsigned int64 0x00007ff6`77e1c000
unsigned int64 0xffffffff`00000006
yes
ModLoad: 00007ff9`c8520000 00007ff9`c8531000   C:\WINDOWS\System32\kernel.appcore.dll
ModLoad: 00007ff9`c9da0000 00007ff9`c9e3e000   C:\WINDOWS\System32\msvcrt.dll
ModLoad: 00007ff9`c9aa0000 00007ff9`c9bc2000   C:\WINDOWS\System32\RPCRT4.dll
ntdll!NtTerminateProcess+0x14:
00007ff9`cc5cfcd4 c3              ret

注意poi(myvar)如何返回64位值,并设置了高32位。您的poi(myvar)> 0n4比较表示:

if (0xffffffff0000000? > 4) then { always true }

使用dwo(myvar)代替只读取32位内容

© www.soinside.com 2019 - 2024. All rights reserved.