《C++Primer》3.16 面向对象编程

在C++中,基类必须指出希望派生类重定义哪些函数,定义为virtual的函数是基类期待派生类重新定义的,基类希望派生类继承的函数不能定义为虚函数。

通过动态绑定我们能够编写程序使用继承层次中任意类型的对象,无须关心对象的具体类型。

一旦函数在基类中声明为虚函数,它就一直是虚函数,派生类无法改变该函数为虚函数这一事实。派生类重定义虚函数时,可以使用virtual保留字,但不是必须这样做。

用作基类的类必须是已定义的。

最常见的继承形式是public

如果进行private或protected继承,则基类成员的访问级别在派生类中比在基类中更受限。

派生类可以恢复继承成员的访问级别,但不能使访问级别比在基类中原来指定的更严格或更宽松。

使用class保留字时默认情况是私有继承,但是实践中私有继承很少,而且显式指定私有继承比依赖于默认更好。

友元关系不能继承。基类的友元对派生类的成员没有特殊访问权限。

如果基类定义了static成员,则整个继承层次中只有一个这样的成员。

基类类型对象既可以作为独立对象存在,也可以作为派生类对象的一部分而存在,因此,一个基类对象可能是也可能不是一个派生类对象的部分,结果,没有从基类引用(或基类指针)到派生类引用(或派生类指针)的(自动)转换。

引用转换不同于转换对象(不改变派生类本身)

基类到派生类不存在自动转换,甚至当基类指针或引用实际绑定到派生类对象时,从基类到派生类的转换也存在限制。

每个类都定义了自己的接口,构造函数只能初始化其直接基类。

派生类构造函数不能初始化基类的成员且不应该对基类成员赋值。

如果派生类定义了自己的复制构造函数,该复制构造函数一般应显式使用基类复制构造函数初始化对象的基类部分,如果派生类定义了自己的赋值操作符,则该操作符必须对基类部分进行显式赋值。派生类析构函数不负责撤销基类对象的成员。

如果基类的析构函数为虚函数,则派生类析构函数也将是虚函数。

构造函数和赋值操作符不是虚函数,析构函数是虚函数。

与基类成员同名的派生类成员将屏蔽对基类成员的直接访问。使用作用域操作符访问被屏蔽成员

虚函数必须在基类和派生类中拥有同一原型。如果基类成员和派生类成员接受的实参不同,就没有办法通过基类类型的引用或指针调用派生类函数。

通过基类类型的引用或指针调用函数时,编译器将在基类中查找该函数而忽略派生类。

将函数定义为纯虚函数能够说明,该函数为后代类型提供了可以覆盖的接口,但是这个类中的版本绝不会调用。

C++中一个通用技术是定义包装类句柄类。句柄类存储和管理基类指针。

对赋值操作符进行操作,必须防止自身赋值。

复制未知类型:句柄类经常需要在不知道对象的确切类型时分配已知对象的新副本,此时可以定义虚操作进行复制。(clone)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值