C語言中的printf

#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看不懂的時候, 可以反彙編看下。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章