您的位置:首页 > 编程语言 > C语言/C++

22.C语言和设计模式(之组合模式)

2014-06-25 10:11 246 查看
原文地址:http://blog.csdn.net/feixiaoxing/article/details/7078836

组合模式听说去很玄乎,其实也并不复杂。为什么?大家可以先想一下数据结构里面的二叉树是怎么回事。为什么就是这么一个简单的二叉树节点既可能是叶节点,也可能是父节点?

[cpp] view
plaincopy

typedef struct _NODE  

{  

    void* pData;  

    struct _NODE* left;  

    struct _NODE* right;  

}NODE;  

    那什么时候是叶子节点,其实就是left、right为NULL的时候。那么如果它们不是NULL呢,那么很明显此时它们已经是父节点了。那么,我们的这个组合模式是怎么一个情况呢?

[cpp] view
plaincopy

typedef struct _Object  

{  

    struct _Object** ppObject;  

    int number;  

    void (*operate)(struct _Object* pObject);  

  

}Object;  

    就是这么一个简单的数据结构,是怎么实现子节点和父节点的差别呢。比如说,现在我们需要对一个父节点的operate进行操作,此时的operate函数应该怎么操作呢?

[cpp] view
plaincopy

void operate_of_parent(struct _Object* pObject)  

{  

    int index;  

    assert(NULL != pObject);  

    assert(NULL != pObject->ppObject && 0 != pObject->number);  

  

    for(index = 0; index < pObject->number; index ++)  

    {  

        pObject->ppObject[index]->operate(pObject->ppObject[index]);  

    }  

}     

    当然,有了parent的operate,也有child的operate。至于是什么操作,那就看自己是怎么操作的了。

[cpp] view
plaincopy

void operate_of_child(struct _Object* pObject)  

{  

    assert(NULL != pObject);  

    printf("child node!\n");  

}  

    父节点也好,子节点也罢,一切的一切都是最后的应用。其实,用户的调用也非常简单,就这么一个简单的函数。

[cpp] view
plaincopy

void process(struct Object* pObject)  

{  

    assert(NULL != pObject);  

    pObject->operate(pObject);  

}  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c语言 设计模式