多重继承Linux

 

这里最后是放自己的数据成员,但这里没有些,两张虚函数表

父亲类的母亲类的,那为什么父亲类在上面,主要还是看继承的顺序,里面的替换情况,是重写那个方法就替换那个方法,子类自己增加的虚函数,放在第一个继承表里面.指针式按步,类型用字节.访问虚函数表里面的内容需要找到vptr的地址,然后通过地址增加来打印出里面的内容

Final

进阶2:final

用来修饰类,让该类不能被继承

理解:使得该类终结!

class XiaoMi {

public:

        XiaoMi(){}

};

class XiaoMi2 final : public XiaoMi  {

        XiaoMi2(){}

};

class XiaoMi3 : public XiaoMi2 {  //不能把XiaoMi2作为基类

};

用来修饰类的虚函数,使得该虚函数在子类中,不能被重写

理解:使得该功能终结!

class XiaoMi {

public:

        virtual void func() final;

};

void XiaoMi::func() { //不需要再写final

        cout <<"XiaoMi::func"<<endl; 

}

class XiaoMi2 : public XiaoMi  {

public:

        void func() {}; // 错误!不能重写func函数

};

进阶3:override

override仅能用于修饰虚函数。

作用:

  • 提示程序的阅读者,这个函数是重写父类的功能。
  • 防止程序员在重写父类的函数时,把函数名写错。

#include <iostream>

using namespace std;

class XiaoMi {

public:

        virtualvoidfunc() { cout <<"XiaoMi::func"<<endl; };

};

class XiaoMi2 : public XiaoMi  {

public:

        voidfunc() override{}

        //void func() override;  告诉程序员func是重写父类的虚函数

        //void func1() override{} 错误!因为父类没有func1这个虚函数

};

intmain(void) {

        XiaoMi2xiaomi;

        return 0;

}

override只需在函数声明中使用,不需要在函数的实现中使用。

  •  项目精讲-遗失的子类析构函数

override是修饰虚函数的,override

消失的子类析构函数

子类虚构函数在调用的时候会被稀释掉了

创建一个类的目的就是需要使用对象,

纯虚函数,

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值