C++ 类和类之间的关系(继承,组合,聚合)

本文深入探讨了C++中的面向对象编程概念,重点介绍了类之间的三种主要关系:继承、组合和聚合。通过实例展示了组合(has-a)如何通过包含对象增强类的功能,聚合(has-a pointer)如何通过指针实现类的功能共享,以及继承(is-a)如何形成类的层次结构。此外,还详细讨论了虚函数在继承中的作用,以及组合与继承结合时的构造和析构顺序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主要介绍一下类与类之间的关系,也就是面向对象编程先介绍两个术语

  • Object Oriented Programming   OOP面向对象编程
  • Object Oriented Design  OOD面向对象设计
  • 对于类与类之间的关系有很多种,但是我认为理解3种足够
  1. Inheritance (继承)
  2. Composition (组合) 
  3. 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的类图为

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值