生活随笔
收集整理的這篇文章主要介紹了
C和汇编-----for循环
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
環(huán)境:VC++
for循環(huán)有三個(gè)表達(dá)式,第一個(gè)表達(dá)式是初始化,在for循環(huán)之前執(zhí)行一次,后面就不執(zhí)行了,第二個(gè)是循環(huán)條件,在執(zhí)行循環(huán)體之前求值,如果為真,執(zhí)行循環(huán)體,如果為假,循環(huán)結(jié)束,第三個(gè)是執(zhí)行更新,在每次執(zhí)行完循環(huán)體后執(zhí)行。下面用個(gè)簡(jiǎn)單的程序來(lái)研究for循環(huán)的反匯編
#include
"stdio.h"int
main()
{int sum
=0;for(int i
=1;i
<=100;i
++){sum
+=i
;}printf("sum=%d\n",sum
);return 0;
}
功能是求1到100的和
反匯編:
5: int sum
=0;
00401028 C7
45 FC
00 00 00 00 mov dword ptr
[ebp
-4],0
6: for(int i
=1;i
<=100;i
++)
0040102F C7
45 F8
01 00 00 00 mov dword ptr
[ebp
-8],1
00401036 EB
09 jmp main
+31h
(00401041)
00401038 8B
45 F8 mov eax
,dword ptr
[ebp
-8]
0040103B
83 C0
01 add eax
,1
0040103E
89 45 F8 mov dword ptr
[ebp
-8],eax
00401041 83 7D F8
64 cmp dword ptr
[ebp
-8],64h
00401045 7F
0B jg main
+42h
(00401052)
7: {
8: sum
+=i
;
00401047 8B
4D FC mov ecx
,dword ptr
[ebp
-4]
0040104A
03 4D F8 add ecx
,dword ptr
[ebp
-8]
0040104D
89 4D FC mov dword ptr
[ebp
-4],ecx
9: }
00401050 EB E6 jmp main
+28h
(00401038)
10: printf("sum=%d\n",sum
);
00401052 8B
55 FC mov edx
,dword ptr
[ebp
-4]
00401055 52 push edx
00401056 68 1C
20 42 00 push offset string
"sum=%d\n" (0042201c
)
0040105B E8
30 00 00 00 call printf
(00401090)
00401060 83 C4
08 add esp
,8
11: return 0;
00401063 33 C0 xor eax
,eax
12: }
從上面的程序我們可以看出mov dword ptr [ebp-8],1相當(dāng)于int i =1;從反匯編的角度看,這個(gè)也執(zhí)行了一次,按照f(shuō)or循環(huán)的執(zhí)行過(guò)程,接下來(lái)應(yīng)該是i<=100,上面反匯編對(duì)應(yīng)程序:
00401041 83 7D F8
64 cmp dword ptr
[ebp
-8],64h
00401045 7F
0B jg main
+42h
(00401052)
比較i和100,如果大于,則跳到00401052執(zhí)行,跳出循環(huán),如果為小于等于,則執(zhí)行
00401047 8B
4D FC mov ecx
,dword ptr
[ebp
-4]
0040104A
03 4D F8 add ecx
,dword ptr
[ebp
-8]
0040104D
89 4D FC mov dword ptr
[ebp
-4],ecx
相當(dāng)于 sum+=i;
循環(huán)體執(zhí)行完就應(yīng)該執(zhí)行`i++了,jmp調(diào)到00401038執(zhí)行
00401038 8B
45 F8 mov eax
,dword ptr
[ebp
-8]
0040103B
83 C0
01 add eax
,1
0040103E
89 45 F8 mov dword ptr
[ebp
-8],eax
這個(gè)就相當(dāng)于i++,接著執(zhí)行i<=100,循環(huán)下去。
C和匯編代碼:
#include
"stdio.h"int
main()
{char
*str
="sum=%d\n";__asm
{mov ebx
,0mov eax
,1
ee
: cmp eax
,100jg endadd ebx
,eaxinc eaxjmp ee
end
: push ebxpush strcall printfadd esp
,8}return 0;
}
總結(jié)
以上是生活随笔為你收集整理的C和汇编-----for循环的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。