C和汇编混合编程----实现浮点数的加减乘除
生活随笔
收集整理的這篇文章主要介紹了
C和汇编混合编程----实现浮点数的加减乘除
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
加法
C程序:
#include "stdio.h"int main() {float a=1.0;float b=2.34;float c;c=a+b;printf("c=%f",c);return 0; }反匯編之后,實(shí)現(xiàn)加法的關(guān)鍵程序
5: float a=1.0; 00401028 C7 45 FC 00 00 80 3F mov dword ptr [ebp-4],3F800000h 6: float b=2.34; 0040102F C7 45 F8 8F C2 15 40 mov dword ptr [ebp-8],4015C28Fh 7: 8: float c; 9: c=a+b; 00401036 D9 45 FC fld dword ptr [ebp-4] 00401039 D8 45 F8 fadd dword ptr [ebp-8] 0040103C D9 55 F4 fst dword ptr [ebp-0Ch] 14: printf("c=%f\n",c); 00401046 83 EC 08 sub esp,8 00401049 DD 1C 24 fstp qword ptr [esp] 0040104C 68 1C 60 42 00 push offset string "c=%f" (0042601c) 00401051 E8 2A 00 00 00 call printf (00401080) 00401056 83 C4 0C add esp,0Ch- 我們定義的浮點(diǎn)數(shù)1.0轉(zhuǎn)成了3F800000h,轉(zhuǎn)化過(guò)程是什么呢?這是個(gè)IEEE 754定義的標(biāo)準(zhǔn),網(wǎng)上有很多現(xiàn)成幫我們轉(zhuǎn),其實(shí)我們可以不必理解這些東西,畢竟人生苦短,學(xué)的東西還很多,能直接用就可以了。(http://www.styb.cn/cms/ieee_754.php#)到這里可以直接轉(zhuǎn)
- fld:將浮點(diǎn)數(shù)壓入到ST(0)出
- fadd:將浮點(diǎn)數(shù)和ST(0)出的浮點(diǎn)數(shù)相加,結(jié)果保存到ST(0)中
- fstp:將ST(0)出數(shù)據(jù)出棧,影響FPU棧內(nèi)數(shù)據(jù),TOP會(huì)減一,將數(shù)據(jù)保存到dword ptr [ebp-0Ch]中
- fst:將ST(0)取出,不影響FPU棧內(nèi)數(shù)據(jù)
改成混合編程為:
#include "stdio.h"int main() {char * str="c=%f\n";__asm{mov dword ptr [esp-4],0x3F800000 ;1.0mov dword ptr [esp-8],0x4015C28F ;2.34fld dword ptr [esp-4]fadd dword ptr [esp-8]fst dword ptr [esp-0ch]sub esp,8fstp qword ptr [esp]mov eax,strpush eaxcall printfadd esp,0ch}return 0; }除法
在C和·匯編混合編程中將fadd 換成fdiv
結(jié)果:
乘法:
將fadd換成fmul
相減:
將fadd換成fsub
用eax這樣的寄存器試了沒成功,如果哪位大佬做出來(lái)了發(fā)我一份,感謝
總結(jié)
以上是生活随笔為你收集整理的C和汇编混合编程----实现浮点数的加减乘除的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 猎金行动剧情介绍
- 下一篇: C和混编混合编程----strcpy缓存