04/23/2020
C++面向对象
C++ 面向对象
面向对象程序设计的核心思想是数据抽象、继承和动态绑定。1
- 数据抽象:类的接口与实现分离,即.h文件和.cpp文件分离、
- 类自身的特性还有一个是封装
- 继承: 定义相似的类型并对其相似关系建模
- 注意层次关系
- 动态绑定: 忽略相似类型的区别
继承
- 基类与派生类是什么?
- 类派生列表如何使用,访问说明符分别代表着什么意思,如果不写,默认是什么?
- 基类虚函数virtual,派生类可以重写(override)虚函数
- 一旦函数被声明成虚函数,则在所有派生类中它都是虚函数。
- 覆盖必须完全模仿函数返回类型和形参列表。
- override关键字用来辅助调试,告诉编译器这个是需要重写基类的虚函数,帮我检查返回类型和形参列表是否一致,或者有没有虚函数可以被重写。
- 派生类必须在其内部对所有重新定义的虚函数进行声明,如果不想重写,可以不要声明。
- protected 访问运算符,基类希望它的派生类有权访问该成员,同时禁止其他用户访问。
- final,防止继承发生的方法,不作基类
继承与静态成员
如果基类有一个静态成员,则整个继承体系中只存在该成员的唯一定义。1 意思就是说,静态成员没有被继承,而是像派生类指向了静态成员,所以只存在唯一的实例
动态绑定(runtime binding)
当我们使用基类的引用或指针调用一个虚函数时将发动动态绑定。1
- 派生类到基类的类型转换,只存在指针或者引用中
- 智能指着也支持类型转换,基类接受派生类
- 静态类型和动态类型是什么?
- 派生类引用或者指针不能接受基类类型
- 向基类的拷贝构造函数或者赋值运算符中传入派生类会发什么?
- 基类只初始化自己的成员变量,派生类独有的被切掉了
- 调用virtual函数,只有在运行中才确认调用谁的函数
- 派生类不想动态绑定,就想使用基类的虚函数怎么办?回避虚函数调用
- 使用作用域运算符实现
- 只有成员函数或者友元中的代码需要使用作用域来回避虚函数
抽象基类
纯虚函数的类是抽象基类
- 纯虚函数是什么?
- 不能创建抽象基类的对象
访问控制与继承
- protected,派生类的成员或友元智能通过派生类对象来访问基金受保护成员。派生类对于一个基类对象中的受保护成员没有任何访问特权、1–难点
class Base
{
protected:
int prot_mem;