/* 压栈顺序和参数计算顺序不是一回事,所以还是看地址更有保证 */
#include
#include
void func(int i,int j,int k);
int main(void)
{
static int a=0;
func(a++,a++,a++);
return 0;
}
void func(int i,int j,int k)
{
int l=1;
int m=2;
int n=3;
int *A=(int *)malloc(sizeof(int)*1);A[0]=0;
int *B=(int *)malloc(sizeof(int)*1);B[0]=1;
int *C=(int *)malloc(sizeof(int)*1);C[0]=2;
printf("k=%d:[%x]\n",k,&k);
printf("j=%d:[%x]\n",j,&j);
printf("i=%d:[%x]\n",i,&i);
printf("___________\n");
printf("l:[%x]\n",&l);
printf("m:[%x]\n",&m);
printf("n:[%x]\n",&n);
printf("___________\n");
printf("A[0] %0x:%d\n",&A[0],A[0]);
printf("B[0] %0x:%d\n",&B[0],B[0]);
printf("C[0] %0x:%d\n",&C[0],C[0]);
free(A); free(B); free(C);
}
栈的增长方向是高地址->低地址 堆是低地址->高地址GCC4.2和VC10中k,j,i结果都是012,不同的是GCC4.2地址递增,VC10地址递减的
猜测GCC从左往右压栈,VC从右往左压栈。
逗号表达式计算顺序从左到右,但函数参数是从右到左的
int a = 5;
printf("%d\n", (a = 2 * 5, a * 4), printf("%d\n", a));
结果:5, 40
阅读(2713) | 评论(0) | 转发(0) |