主要介绍一下类与类之间的关系,也就是面向对象编程先介绍两个术语
- Object Oriented Programming OOP面向对象编程
- Object Oriented Design OOD面向对象设计
- 对于类与类之间的关系有很多种,但是我认为理解3种足够
- Inheritance (继承)
- Composition (组合)
- Delegation (委託) 该种关系也可以理解成聚合
一:组合 Composition
1.定义: has-a的关系,一个类中有包含另外一个类 (类中的成员变量之一是类),是包含一个对象,而不是包含一个指针,如果你组合了这个类,那么你就将拥有你包含的类的全部功能
- 下面我介绍一个组合的实际应用
#include<deque>
#include <queue>
template <class T>
class queue {
...
protected:
std::deque<T> c; // 底層容器 has-a的关系
public:
// 以下完全利用 c 的操作函數完成
bool empty() const { return c.empty(); }//利用deque的功能来实现queue新定义的功能
size_t size() const { return c.size(); }
reference front() { return c.front(); }
reference back() { return c.back(); }
void push(const value_type& x) { c.push_back(x); }
void pop() { c.pop_front(); }
};
- queue是一种队列操作,单方向操作先进先出
- deque是两端都可进出,所以说deque的功能较强大与quque,但是如果我queue组合deque(包含 has-a)那么我们就可以利用deque的功能来实现queue新定义的功能
- 这就是组合关系的一种实际应用,同时它也是adapter(适配器)设计模式
2.用类图表示has-a的模式,Container(容器) Component(组成部分 part) Container has Component
- 那么上面的queue与deque的类图为