我寫了下面的程序:爲什麼使用JLE而不是JL?
#include <stdio.h>
int main()
{
int i = 0;
for (; i < 4; i++)
{
printf("%i",i);
}
return 0;
}
我使用gcc test.c -o test.o
編譯它,然後使用objdump -d -Mintel test.o
拆開它。彙編代碼我得到了(至少相關部分)如下:
0804840c <main>:
804840c: 55 push ebp
804840d: 89 e5 mov ebp,esp
804840f: 83 e4 f0 and esp,0xfffffff0
8048412: 83 ec 20 sub esp,0x20
8048415: c7 44 24 1c 00 00 00 mov DWORD PTR [esp+0x1c],0x0
804841c: 00
804841d: eb 19 jmp 8048438 <main+0x2c>
804841f: 8b 44 24 1c mov eax,DWORD PTR [esp+0x1c]
8048423: 89 44 24 04 mov DWORD PTR [esp+0x4],eax
8048427: c7 04 24 e8 84 04 08 mov DWORD PTR [esp],0x80484e8
804842e: e8 bd fe ff ff call 80482f0 <[email protected]>
8048433: 83 44 24 1c 01 add DWORD PTR [esp+0x1c],0x1
8048438: 83 7c 24 1c 03 cmp DWORD PTR [esp+0x1c],0x3
804843d: 7e e0 jle 804841f <main+0x13>
804843f: b8 00 00 00 00 mov eax,0x0
8048444: c9 leave
8048445: c3 ret
我發現,雖然我比較操作是i < 4
,彙編代碼是(在拆解後)i <= 3
。爲什麼會發生?爲什麼它會使用JLE
而不是JL
?
這可能是鼓勵後續優化的代碼,如循環展開。哪些沒有發生,避免看未經優化的代碼。 –
這實際上是一個gcc代碼生成選擇(您需要深入代碼的樹形表示),但它會將一個var
Petesh