压栈顺序
1.参数
2.返回地址
3.调用函数栈基址()
4.临时变量空间
5.寄存器信息一般为EBX,ESI.EDI。
6.栈结构遵循先进后出的顺序,堆,栈是两个不同的概念,函数调用过程中参传递的顺序根据调用约定来执行,标准调用约定和C约定都是从右往传参,快速约定从左往右传参,参数多于两个的通过寄存器穿参,多出的通过栈传参,函数返回值默认在EAX中。
7.约定:有且仅有一方释放参数的栈空间,栈平衡:栈顶在调用前后地址一样,
__stdcall--标准约定:调用方平衡堆栈 __cdecl调用方平衡堆栈:__fastcall被调方平衡栈
如果要改变某个函数的调用约定,在函数返回类型后加上所要调用的约定。
例如:int __stdcall change(int x,int y)
{
}
#include<stdio.h>
#include<stdlib.h>
int a(int a,int b);
int name(int n,int m);
void main()
{
int x = 5,y = 8;
a(x,y);
system("pause");
}
int a(a,b)
{
a=10,b=7;
name(a,b);
return 0;
}
int name(int n,int m)
{
n=2,m=4;
return 0;
}
1---地址0018FF48--0018EF4处开始为主函数main()的栈空间,黄颜色隔开的代表调用main()函数的函数压入的寄存器信息ccccc代表栈中开辟的临时变量空间,0018FF88代表返回地址,08000000,050000000为主函数中定义的两个变量的值,因为主函数为无参函数所以没有参数信息压入栈。
2--地址0018FEE4---0018FE98为函数a()的栈空间。其中07000000,0A000000为压入的参数,B3D44000为返回地址,48FF1800为main()函数栈信息,
CCCC为变量空间0018FEA0---0018FE98为压入的三个寄存器数据EBX=7EFDE000 , ESI=00000000, EDI=0018FEE4
3—函数3同二