class VirtualSizec++ {函数 virtual void function_name() {}spa
int data;3d } v;指针
///虚函数指针对象 ///cout << sizeof(v) << endl; ///在存在virtual函数的时候多四个字节blog |
若是咱们把 virtual注释答案是4,有virtual,无论多少,只要有,就会多四个字节的虚表指针。这就是编译器默默给咱们加上的部分内存
在内存中模型以下ci
类结构:编译器
class A { public: virtual void vfun1() { cout << "A vfun1" << endl; } virtual void vfun2() { cout << "A vfun2" << endl; } void fun1() { cout << "A fun1" << endl; } void fun2() { cout << "A fun2" << endl; } private: int data1, data2; };
class B: public A{ public: virtual void vfun1() { cout << "B vfun1" << endl; } void func2() { cout << "B fun2" << endl; } private: int data3; };
class C: public B { public: virtual void vfun1() { cout << "C vfun1" << endl; } void fun2() { cout << "C fun2" << endl; } private: int data1, data4; }; |
在过去,c语言调用函数经过call 【函数地址】,调用,调用完在回来,这叫静态绑定。
而如今状况不是这样
在面向对象中,存在虚表指针,寻找虚表,再看看调用那个函数
总结:c++编译器看到函数,会先考虑是静态绑定仍是动态绑定,静态绑定相似call xxx。
符合某些条件会作动态绑定。虚拟机制(多态)
1, 指针调用
2, 向上转形
3, 调用的是虚函数
而后创建入上图的机制,觉定到底使用那个东西