#include<stdio.h>
void main()
{
int i=8;
printf(" %d\n %d\n %d\n %d\n %d\n %d\n",++i,--i,i++,i--,-i++,-i--);
}
#include<stdio.h>
void main()
{
int i=8;
printf("%d\n",++i);
printf("%d\n",--i);
printf("%d\n",i++);
printf("%d\n",i--);
printf("%d\n",-i++);
printf("%d\n",-i--);
}
兩者的區別
像這種問題應該與編譯器有關,在vc環境下的結果是8788-8-8
因爲,在vc下,printf函數中,右自增自減是無法實現的,也就是等於沒有,可以看看反彙編的代碼
0040D78F mov eax,dword ptr [ebp-4]
0040D792 neg eax
0040D794 mov dword ptr [ebp-8],eax
0040D797 mov ecx,dword ptr [ebp-8]
0040D79A push ecx
這是最後一個參數的反彙編,因爲在C語言中,參數的調用,是從右到左的參數壓入堆棧,所以先壓入的是最後一個I,由於用了負號,所以,最後一個是-8,從右到左第二個一樣,也用了負號,所以也是-8依此第三個,沒有加負號,所以是8,再依次,還是8,最後兩個,也就是從左到右第一二個,從右到左第5 ,6個,開始有變化了,我可以給你反彙編的代碼看看,他們是左自增(自減),也就是先自增再使用,所以從右到左第5個,是7,是由於它自減,你可以看看反彙編代碼
0040D7BB mov edx,dword ptr [ebp-4]
0040D7BE sub edx,1
0040D7C1 mov dword ptr [ebp-4],edx
0040D7C4 mov eax,dword ptr [ebp-4]
0040D7C7 push eax
可以看到,先是把i的值給了寄存器值是8,再減-1就是7了,再把值賦值給i,那個,[ebp-4]就是i的地址,壓入堆棧的時候是7,再看看最後壓入堆棧的,
0040D7C8 mov ecx,dword ptr [ebp-4]
0040D7CB add ecx,1
0040D7CE mov dword ptr [ebp-4],ecx
0040D7D1 mov edx,dword ptr [ebp-4]
0040D7D4 push edx
開始,[ebp-4]由於開始已經是7了,所以,add 加1後,就是8了,再把8給,[ebp-4]所以,最後i的值還是8,壓入堆棧的時候,edx是8,所以,依此排列下來,壓入的順序就是,
-8
-8
8
8
7
8
最後堆棧的特點你應該瞭解吧,先入的後出,也就是,從下面開始調出,
最後,就是
8788-8-8
看C看不懂的時候, 可以反彙編看下。
C語言中的printf
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.