#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--);
}
兩者的區(qū)別
像這種問題應(yīng)該與編譯器有關(guān),在vc環(huán)境下的結(jié)果是8788-8-8
因為,在vc下,printf函數(shù)中,右自增自減是無法實現(xiàn)的,也就是等于沒有,可以看看反匯編的代碼
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
這是最后一個參數(shù)的反匯編,因為在C語言中,參數(shù)的調(diào)用,是從右到左的參數(shù)壓入堆棧,所以先壓入的是最后一個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]由于開始已經(jīng)是7了,所以,add 加1后,就是8了,再把8給,[ebp-4]所以,最后i的值還是8,壓入堆棧的時候,edx是8,所以,依此排列下來,壓入的順序就是,
-8
-8
8
8
7
8
最后堆棧的特點你應(yīng)該了解吧,先入的后出,也就是,從下面開始調(diào)出,
最后,就是
8788-8-8
看C看不懂的時候, 可以反匯編看下。