设计模式之Composite模式

Composite模式用于描述可以自包含的场景,如文件系统中文件夹包含子文件夹,或圆包含子圆。它结合继承和委托,通过一个基类实现添加功能,允许添加单一元素或组合。举例说明,Circle类可以包含SingleCircle或更多Circle,模拟文件夹结构。代码实现展示了在C++中如何应用此模式,并提供了测试运行结果。

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

适用场景

        Composite模式适用于可以自包含的情况,比如说一个文件夹包含多个子文件夹,每个子文件夹又可以包含多个子文件夹。类似的问题还有:一个圆可以包含许多小圆,每一个小圆内部又可以包含多个圆。

模式介绍

        Composite模式主要涉及到继承和委托(Delegation)的结合,此处以圆为例的UML图如下所示:其中SingleCircle为单一圆,Circle为正常的圆里面可以包含多个其他的圆,由于Circle的成员变量要能够添加单个的圆或者很多圆,因此使用一个CircleBase作为其基类,并有一个virtual add function, SingleCircle代表单个圆,因此不需要重写add函数,Circle里重写add函数并以基类指针CircleBase*作为指针(即委托),这样即可以添加SingleCircle,又可以添加Circle。同样把Circle换成File可以来描述文件包含多个文件的情况。

模式实现

以下代码为前面UML图的实现,并测试了Composite模式

#include <vector>
#include <iostream>

class CircleBase
{
private:
	int m_Value;

public:
	CircleBase(int value)
		:m_Value(value)
	{}
	virtual void add(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值