C++面向对象模型(虚表与虚表指针)

 

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, 调用的是虚函数

 而后创建入上图的机制,觉定到底使用那个东西

相关文章
相关标签/搜索