类和类之间的三大关系
?Inheritance (继承)
?Composition (组合)
?Delegation (委托)
Composition (组合),:表示 has-a
的关系
(我里头有一个这种东西:表示has-a)
组合关系下的构造和析构:
构造(ctor) 由内而外进行
Container的构造函数首先调用Component的default构造函数,然后才执行自己。(如果没有默认构造函数,编译器添加默认构造函数)
析构(dtor) 由外而内进行
Container的析构函数首先执行自己,然后才调用Component的析构函数。
Delegation(委托):Composition by reference
为什么叫委托?
我拥有一个指针指向你时,我就可以在任何时间点调用你,委托你做事情
(组合是生命一起出现的)
pimpl: 由一个指针指向真正实现功能的类 (handle(左) / body(右))
左边是对外的接口,真正的实现由右边做
(右边怎么动都不会影响左边:编译防火墙)
Inheritance(继承):表示 is-a
的关系
人类是一种哺乳类 哺乳类是一种动物 动物是一种生物 代表is-a的关系
继承关系下的构造和析构
- 构造(ctor)
由内而外进行,Derived的构造函数首先调用Base的default构造函数,然后才执行自己。
- 析构(dtor)
由外而内进行,Derived的析构函数首先执行自己,然后才调用Base的析构函数。
base class的
dtor
必须是virtual
,否则会出现 undefined behavior。
Inheritance(继承)with virtual functions(虚函数):
- non-virtual 函数:你不希望 derived class 重新定义(override,重写)它
- virtual 函数:你希望 derived class 重写它,且你对它已有默认的定义。
- pure virtual 函数:你希望 derived class 一定要重写它,你对它没有默认的定义(其实也可以有定义,不过一般情况下没有默认的定义)。
Inheritance(继承) + Composition(组合) 关系下的构造和析构:
- 构造(ctor)
由内而外进行,Derived 的构造函数首先调用 Base 的 default 构造函数,然后调用 Component 的 default 构造函数,最后才执行自己。
- 析构(dtor)
由外而内进行,Derived 的析构函数首先执行自己,然后调用 Component 的析构函数,最后调用 Base 的析构函数
如果一个 class 作为 base class,则它的析构函数应该设计为 虚析构函数。
Delegation (委托) + Inheritance (继承) (功能最强大)
Observer观察者模式
文件只有一份 窗口有四个
表示文件的类:一个是存储数据 一个是表现数据 ; 如果一个变化 其他也要跟着变化 要怎么解决?
设计一个class叫subject (放数据) 再设计一个叫observer
我们可以让左边可以拥有很多个右边 因为使用者可能开多个窗口观察右边可以被继承(父类) 这样就可以拥有变化 作为内容class 应该提供注册(attach)和注销 还应该有一个函数notify 遍历通知所有的观察者
Composite 组合模式
prototype 原型模式