浮点指令的逆向求解

本文介绍了一种通过编写C++代码并观察其汇编指令来逆向求解浮点数比较的方法。作者利用VC2005的调试功能,展示了如何通过具体的汇编指令判断两个浮点数的大小。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

浮点指令的逆向求解
Author:zfive5(zhaozidong)
Email:zfive5@yahoo.com.cn
晚上在csdn上看到一个网友给我发过来的一个浮点运算指令的问题,说实话之前没有怎样使用,对它的内部也不是特别清楚,只是业余时简单翻过书而已,但灵机一动想到另类求解方法,在vc2005下编写一个两个浮点数比较的c++代码,然后在调试状态下看汇编代码就可以得到结果了,真可谓条条大路通罗马。
int _tmain(int argc, _TCHAR* argv[])
{
float a1=1.0;
float a2=2.0;
if(a1>a2)
{
return 1;
}
return 2;
}
int _tmain(int argc, _TCHAR* argv[])
{
00411360push ebp
00411361mov ebp,esp
00411363sub esp,0D8h
00411369push ebx
0041136Apush esi
0041136Bpush edi
0041136Clea edi,[ebp-0D8h]
00411372mov ecx,36h
00411377mov eax,0CCCCCCCCh
0041137Crep stos dword ptr es:[edi]
float a1=1.0;
0041137Efld1
00411380fstp dword ptr [a1]
float a2=2.0;
00411383fld dword ptr [__real@40000000 (41563Ch)]
00411389fstp dword ptr [a2]
if(a1>a2)
0041138Cfld dword ptr [a1]
0041138Ffld dword ptr [a2]
00411392fcompp
00411394fnstsw ax
00411396test ah,5
00411399jp wmain+42h (4113A2h)
{
return 1;
0041139Bmov eax,1
004113A0jmp wmain+47h (4113A7h)
}
return 2;
004113A2mov eax,2
}
这些天真的忙,闲暇还是要看书和听音乐,周围都是小朋友,发现自己老了!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值