关于Virtual Base Class的几点说明

关于Virtual Base Class的几点说明

先看以下的几个程序的输出的多少

1

#include <iostream>

using namespace std;

void main()

{

       class a{};

       class b:public virtual a{};

    class c:public virtual a{};

       class d:public b,public c{};

       cout<<sizeof(a)<<endl<<sizeof(b)<<endl<<sizeof(c)<<endl<<sizeof(d)<<endl;

}

2

#include <iostream>

using namespace std;

void main()

{

       class a{int i;};

       class b:public virtual a{int j;};

    class c:public virtual a{int k;};

       class d:public b,public c{};

       cout<<sizeof(a)<<endl<<sizeof(b)<<endl<<sizeof(c)<<endl<<sizeof(d)<<endl;

}

3

#include <iostream>

using namespace std;

void main()

{

       class a{};

       class b:public a{};

    class c:public a{};

       class d:public b,public c{};

       cout<<sizeof(a)<<endl<<sizeof(b)<<endl<<sizeof(c)<<endl<<sizeof(d)<<endl;

}

4

#include <iostream>

using namespace std;

void main()

{

       class a{int i;};

       class b:public a{int j;};

    class c:public a{int k;};

       class d:public b,public c{};

       cout<<sizeof(a)<<endl<<sizeof(b)<<endl<<sizeof(c)<<endl<<sizeof(d)<<endl;

}

具体的结果得更具具体的编译器而定

 

 

 

VC上运行得出来的结果分别是

11 4 4 8

24 12 12 20

31 1 1 1

44 8 8 16

 

 

 

在原始一点的C++编译器上运行的结果又会不一样

11 8 8 12

24 12 12 20

31 1 1 1

44 8 8 16

 

 

 

 

 

 

出现上面的结果主要是因为:

不想写了 ,想知道请留言 我会一一解答

class的动态绑定是指在运行时确定对象的实际类型,并调用相应的方法。这种机制在面向对象编程中非常重要,特别是在使用继承和多态时。动态绑定使得程序在运行时能够根据对象的实际类型来决定调用哪个方法,而不是在编译时确定。 动态绑定的实现方式通常依赖于虚函数表(vtable),每个类都有一个虚函数表,表中存储了指向其虚函数的指针。当一个对象调用虚函数时,程序会通过对象的虚函数表指针找到对应的函数并执行。 以下是动态绑定的几个关键点: 1. **虚函数**:在基类中使用`virtual`关键字声明的函数。子类可以重写这些函数,以提供自己的实现。 2. **对象指针**:通过基类指针调用虚函数时,实际执行的是对象实际类型的实现。 3. **运行时确定**:动态绑定在程序运行时确定调用哪个函数,而不是在编译时。 示例代码: ```cpp #include <iostream> class Base { public: virtual void display() { std::cout << "Display from Base" << std::endl; } }; class Derived : public Base { public: void display() override { std::cout << "Display from Derived" << std::endl; } }; int main() { Base* b = new Derived(); b->display(); // 输出 "Display from Derived" delete b; return 0; } ``` 在这个例子中,`Base`类定义了一个虚函数`display`,`Derived`类重写了`display`函数。当我们通过基类指针`b`调用`display`函数时,实际调用的是`Derived`类的实现,这就是动态绑定的效果。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值