刚学完this指针这一块 就顺便整理整理思路:
struct Count
{
int x=2, y;
int add(int x, int y)
{
this->x = x;
this->y = y;
return this->x + this->y;
}
};
int _tmain()
{
Count c;
c.add(5,6);
return 0;
}
012C3F18 push 6
012C3F1A push 5
012C3F1C lea ecx,[ebp-10h] //ebp-10h 即是结构体的首地址 也就是this指针
012C3F1F call 012C123A //c.add(5,6);
//成员函数内部
0993EF0 push ebp
00993EF1 mov ebp,esp
00993EF3 sub esp,0CCh
00993EF9 push ebx
00993EFA push esi
00993EFB push edi
00993EFC push ecx
00993EFD lea edi,[ebp+FFFFFF34h]
00993F03 mov ecx,33h
00993F08 mov eax,0CCCCCCCCh
00993F0D rep stos dword ptr es:[edi]
00993F0F pop ecx //this指针
/*结构体的首地址==this指针
结构体的首地址==this指针
结构体的首地址==this指针
结构体的首地址==this指针
结构体的首地址==this指针
结构体的首地址==this指针*/
00993F10 mov dword ptr [ebp-8],ecx
00993F13 mov eax,dword ptr [ebp-8]
//将第一个参数赋值给结构体的首地址(this指针)
00993F16 mov ecx,dword ptr [ebp+8] //ebp+8第一个参数的值
00993F19 mov dword ptr [eax],ecx
00993F1B mov eax,dword ptr [ebp-8]
00993F1E mov ecx,dword ptr [ebp+0Ch] //ebp+0Ch第二个参数的值
//将第二个参数赋值给结构体的首地址偏移+4
00993F21 mov dword ptr [eax+4],ecx //eax当前为this指针
00993F24 mov eax,dword ptr [ebp-8]
00993F27 mov eax,dword ptr [eax] //将结构体首地址解引用并赋值给eax
00993F29 mov ecx,dword ptr [ebp-8] //将结构体首地址解引用并赋值给ecx
//结构体首地址+=结构体首地址+0x4 ==this->x + this->y
00993F2C add eax,dword ptr [ecx+4]
00993F2F pop edi
00993F30 pop esi
00993F31 pop ebx
00993F32 mov esp,ebp
00993F34 pop ebp
00993F35 ret 8 //相当于 pop eip ,add esp,8
1.调用成员函数时会将this指针传进函数内部
2.结构体的地址==this指针
3.成员函数的调用约定方式为_thiscall自右向左传参 ,函数内平衡堆栈。
4.空结构体(类)占的字节数为1byte
5.成员函数在结构体内部不占空间
若是有错误之处 还请指明!多谢