参数压栈顺序
最近看一些linux底层实现,随手记录点东西。
复习下c/c++参数压栈,看下面的例子:
void foo(unsigned char x, int y, long long z){
cout<<“x:”<<hex<<(void*)&x<<endl;
cout<<“y:”<<hex<<&y<<endl;
cout<<“z:”<<hex<<&z<<endl;
}
C/C++按照从右到左顺序传参,xyz按照zyx顺序入栈。且栈是从内存高地址向低地址方向增长,所以xyz的地址是递增的?
写了个demo用GCC跑了下:
难道这里参数"入栈的顺序”是xyz?其实不然,压栈顺序是站在调用者角度考虑的,即上图中mov $0x12c,%edx开始的3句指令,这里采用寄存器传参,对应着
push $0x12c
push $0xc8
push $0x64
所谓的压栈顺序,不是站在foo函数内看的,是站在调用者堆栈看,这里采用寄存器传参容易隐藏掉这个细节
错误遗留之处欢迎指正