函数参数入栈顺序
#include
void foo(int x, int y, int z)
{
printf("x = %d at [%X]\n", x, &x);
printf("y = %d at [%X]\n", y, &y);
printf("z = %d at [%X]\n", z, &z);
}
int main(int argc, char *argv[])
{
foo(100, 200, 300);
return 0;
}
运行结果是:
x = 100 at [...60]
y = 200 at [...64]
z = 300 at [...68]
这是由于,C程序栈的内存生长方式是往低地址内存生长,这