0

说我有以下代码:

C++ 代码和内联汇编代码如下:

方程:

X=40+5 
Y=3*12 ---> X=45 Y=36

测试

if x < y - print x+y

else print x-y

int main()
{   
 int x=5,y=3,z=0;
 x=x+40;
 y=y*12;
 if(x<y) //45<36 - cond. is NOT met
      z=x+y; 
 else
     z=x-y; 
 cout << "z:" << z << endl; // z=9
     x=5,y=3,z=0;
 __asm
 {
     pushad
         mov eax,0
         mov ebx,0
         mov eax,x
         add eax,40
         mov ebx,y
         imul ebx,12
         cmp eax,ebx
         jb First ;cond is NOT met
         jmp Second ;we jump to Second label
 First: add eax,ebx
         mov z,eax
 Second: sub eax,ebx
         mov z,eax
     popad

 }
 cout << "z:" << z << endl; //z=9
 return 0;
}

两个结果都产生 z=9,但是如果我分别在 C++ 和汇编代码中更改 y=-3(int x=5,y=-3,z=0;AND in x=5,y=-3,z=0;)我必须得到 z=81,但是内联汇编的输出是 z=45,所以我不能正确加载 ebx 寄存器中的负值(-3)...我的问题是如何在 ebx 中加载 -3 ,以便得到 45-(-36)=81 ?

4

3 回答 3

3

我认为您遇到的问题是jb使用无符号比较;你可能想jl改用。

于 2012-11-23T15:06:43.137 回答
2

两个问题 - 正如其他人指出的那样,一个是您使用了基于无符号比较的分支指令。

另一种是,执行完里面的代码First,然后再执行里面的代码Second。你通常希望有一个无条件jmp的 to after Second。此刻,您添加然后立即再次减去。

所以你可能想要:

        cmp eax,ebx
        jge Second ;cond is not met (I've removed one branch and reversed the test)
First:  add eax,ebx
        jmp Store
Second: sub eax,ebx
Store:  mov z,eax ;shared by both paths
于 2012-11-23T15:11:23.350 回答
1

使用JL而不是JB. 一种是有符号比较,另一种是无符号比较。

于 2012-11-23T15:07:07.757 回答