c++组合模式

将内部数据结构与客户代码隔离,不论内部结构是什么样子,客户代码调用方式不变(invokeAll函数)

component.h

#ifndef _THREAD_POOL_H
#define _THREAD_POOL_H
#include <list>
#include <string>

using namespace std;

class component
{
public:
    component(int id, string name): m_id(id), m_name(name){}
    virtual void doTask() = 0;
    virtual ~component(){};
protected:
    int m_id;
    string  m_name;
};


//相当于树的非叶子节点
class Composite :public component{
public:
    void doTask()override;
    void add(component *pComponent);
    void remove(component *pComponent);
private:
    list<component *> m_childs;
};

//相当于树的叶子节点
class Leaf :public component{
public:
    void doTask()override;
};

void invokeAll(component * c);
#endif

component.cpp

#include "component.h"
#include <iostream>
using namespace std;


//类似于树的遍历
void Composite::doTask(){
    printf("composit   id: %d, name :%s do task\n", m_id, m_name.c_str());
    for(auto &e : m_childs){
        e->doTask();
    }
}

void Composite::add(component *pComponent){
    m_childs.push_back(pComponent);
}
void Composite::remove(component *pComponent){
    m_childs.remove(pComponent);
}

void Leaf::doTask(){
    printf("leaf   id: %d, name :%s do task\n", m_id, m_name.c_str());
}

void invokeAll(component* c){
    c->doTask();
}



main.cpp

#include "component.h"
using namespace std;

int main(){
    Composite  root(1, "root");
    Composite  left(2, "left");
    Composite  right(3, "right");
    Leaf  left_leaf1(4, "left_leaf1");
    Leaf  left_leaf2(5, "left_leaf2");
    Leaf  right_leaf1(6, "right_leaf1");
    Leaf  right_leaf2(7, "right_leaf2");

    root.add(&left);
    root.add(&right);
    left.add(&left_leaf1);
    left.add(&left_leaf2);
    right.add(&right_leaf1);
    right.add(&right_leaf2);

    invokeAll(&root);
    
    return 0;
};

``

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值