- 类型转换:自动转换,显示转换,强转
总结:CPP编译的时候,从上往下,遇到不匹配,声明扩展了一个类的作用域(此时最多只能创建类的指针或者引用), 由于没有定义是不可能使用到类的成员
完成类型转换的时候,一般两个类的转换,两个接口都放在下面的那个类里面实现
- 手动类型转换:构造函数类型转换,赋值重载,operator XXXX()
- 构造函数类型转换:给一部分的数据,内部可以自己调节,那么这部分的数据就可以成为往该类转换(外->内)
- 赋值重载:跟构造函数一个原理,阶段是在赋值的时候,而不是初始化的时候(外->内)
- operator XXXX() 接口要求:不能有返回值,参数必须为空,函数名为要转换的类型名
函数内部要求必须有返回值(内->外)
首先就得创建这种类型的对象毕竟要返回这种类型的对象
只能是成员函数,拥有this,因为必须操作成员数据(重载类型)返回的时候一定是与类型名相同的那个类型
补充:流运算符的重载:friend ostream& operator <<(ostream & os, const yourclass & yu10);
并不是成员,和类是完全隔离的,属于:友元重载
- 释放的时候是从下往上,构造函数不可以互相包含,造成死锁
头文件互相包含,互相引用对象,引用还有指针的时候可以编译但是不能执行
- 引用外部函数需要声明。。
类的声明只能定义类的指针或者引用,类的头文件之后(相当于定义了)(因为头文件整个的函数体系已经出来了,)
3.多继承功能迭代多,但是牵连很多,难维护
继承会把爹的所有元素都继承过来
继承的本质:子类直接把整个父类包含进去,多继承也不例外,重复的包都没有问题
真正的核心在于:运用了类似命名空间的走法来区分层次上的关系
比如想使用父类的成员,子类也有, B.A::n;使用命名空间的走法来区分层次上的结构
继承之后,按照源代码块整体的提取过来,数据是分离的,这就很明显了嘛
- 静态函数和成员函数本质的区别:不需要this指针,不依赖于一个对象
- 静态私有成员得有接口set,get
5.对protected的理解:只能说类的设计者(子类的设计)在继承的关系中是可以访问的,但是类的调用者是不可访问的(在Main这个层次进行操作)
6.本类的设计者(private),继承链中的设计者(protected),Main那边的调用者(public)
7.继承链:构造的时候:从基类开始构造,析构的时候:从派生类到基类
在继承链中,各自的成员数据由各自的构造函数进行初始化
(现在可以发现:在继承链中派生类的构造函数必须提供接口提供给基类去初始化各自类的数据成员)递归式的调用初始化
继承链中,派生类是整体的把基类完全的收入囊中,派生类实体和基类实体之间的操作互不相干,框架上是继承链模式
8.虚继承正对于多继承而言,派生类继承的多个基类中含有重复的基类,此时产生的浪费内存,产生二义性。。。。。。
虚继承之后相同的基类只开辟一个内存块,所有的像指针那样指向同一片内存
虚基类:就是容易出现重合的类
9.虚函数提供一个接口
多态主要依赖于继承和virtual,主要用于软件的扩展,(说到底软件的扩展就是依赖于接口的提供,然后把新的功能放进去)由于多态只能小接口的指针所以对于多功能就体现在virtual这个虚函数上面,利用虚函数实现多个不同的功能再用动态绑定就可以了
10异构结构:每个成员都是基类的指针,然后分别指向不同的在堆上开辟的派生类对象,实现了一个数据结构上的动态绑定---------多态
基类指针基于多态与虚函数调用派生类的方法