C++调用空指针对象的成员函数成功的理解
2017-09-07 19:15
561 查看
前言
之前在与朋友聊天的时候说到C++中定义的空类对象指针(nullptr),也可以调用类的成员函数,不用进行具体的实例初始化。示范代码是这样的:class A{ public: static void func1() { cout << __FUNCTION__ << endl; } public: void func2() { cout << __FUNCTION__ << endl; } }; int main(){ A *a = nullptr; cout << "a:" << a << endl; A::func1(); a->func1(); a->func2(); return 0; }
上面的两个函数都能够正常的进行输出打印。这其中的原理就涉及到C++的静态绑定和动态绑定了。
原理
因为对于非虚成员函数,C++这门语言是静态绑定的。这也是C++语言和其它语言Java, Python的一个显著区别。但是C++中为什么要进行这样的定义呢?答案是处于性能的考虑。为了节约内存和提高调用效率,一般类成员的存储分成两块,一块是单个instance所有,比如非静态成员变量,另一块是所有instances共享的,比如函数代码。这样的布局是对于性能有好处的,代码只要load一次,减少了cache占用和miss。如果你的函数不引用任何instance独有的内存部分,nullptr并无问题,因为不会使用this,只会使用类instance共享的部分,这部分始终存在,即使你没有任何类实例。反之就会出问题,因为你试图访问不存在的数据。例1. 如下面我们试图按照之前的方式访问,类中定义的成员变量的时候就会报错:
class A{ public: int m_num; public: void func2() { cout << __FUNCTION__ << " " << this->m_num << endl; } }
例2. 当试图按照之前的方式去访问类中定义的虚函数的时候,也会报错。这是因为这就是不是静态绑定的范畴了:
class A{ public: virtual void func3() { cout << __FUNCTION__ << endl; } };
相关文章推荐
- C++利用类静态变量,实现伪类对象空指针成功访问含有成员变量的成员函数而不崩溃
- C++调用空指针对象的成员函数——静态绑定与动态绑定
- C++中通过派生类调用第二基类的普通成员函数时this指针的调整
- C++调用一个成员函数的需求this指针的情况
- 深入探索C++对象模型之指向成员函数的指针
- 【深度探索c++对象模型】Function语义学之成员函数调用方式
- 深入理解C++对象模型-成员函数的本质以及虚函数的实现(非虚继承)
- C++指针直接调用类成员函数探讨
- C++成员函数指针定义和调用
- C++指针直接调用类成员函数探讨
- C/C++中为什么在类外利用多态基类指向派生类指针可以调用类的私有成员函数?
- c++指针深入全面总结--包括对象数据成员和成员函数的指针
- C++成员函数指针及C++函数对象
- C++成员函数 this指针 调用约定
- C++中关于指向对象成员函数打指针例子
- 浅谈C++指针直接调用类成员函数
- c++ 如何把this指针传入成员函数 像全局函数一样调用成员函数
- 对象指针为NULL,为什么还是可以调用成员函数
- c++对象内存布局与c++成员函数指针
- C++对象模型的那些事儿之六:成员函数调用方式