此用一个小示例来说明c++中成员函数是怎么调用的
#includeusing namespace std; class Test{ public: void funcMember(){ cout << "I'm member function" << endl; int *ptr = reinterpret_cast (const_cast (this)); //int *ptr = (int*)(const_cast (this)); cout << *ptr << endl; //没弄清为什么在int x; int y;再栈中的部局中间竟有8个字节的cc cc cc cc cc cc cc cc本应x,y紧挨着的 ptr += 3; //所以就因为多了两个4字节就加了3 cout << *ptr << endl; ptr += 3; cout << *ptr << endl; ptr += 3; cout << *ptr << endl; ptr += 3; cout << *ptr << endl; } Test():x(3){} int x; }; int main(){ Test *t = NULL, *ptr; int x = 10; int y = 20; int z = 30; int zz = 40; Test tt; // t->funcMember(); ptr = &tt; ptr->funcMember(); cout << "--------------------------" << endl; tt.funcMember(); return 0; }
先来说明一下,被注释掉的部分,为什么t是空指针,这样的调用还成功呢
请看下图反汇编后的结果

因此第一处画红线的部分,图中漏掉了一
< http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+xMfU2b+0sbvXosrNtfS687PM0PK1xNTL0NC94bn7yOe6zsTYo788L3A+CjxwPjxpbWcgc3JjPQ=="https://www.cppentry.com/upload_files/article/49/1_uquuw__.jpg" alt="">
从结果中可以看出,对象的实例是作为地址传入函数中的,因此只要不使用此地址,无论它是否为空都不会错误,如果使用了向本示例所做的那样,
知道原因也可以灵活改变。