C语言和设计模式(之组合模式)【文章都是来自网络,只要自己吸取了就是自己的】

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

  1. typedef struct _NODE  
  2. {  
  3.     void* pData;  
  4.     struct _NODE* left;  
  5.     struct _NODE* right;  
  6. }NODE;  
    那什么时候是叶子节点,其实就是left、right为NULL的时候。那么如果它们不是NULL呢,那么很明显此时它们已经是父节点了。那么,我们的这个组合模式是怎么一个情况呢?

  1. typedef struct _Object  
  2. {  
  3.     struct _Object** ppObject;  
  4.     int number;  
  5.     void (*operate)(struct _Object* pObject);  
  6.   
  7. }Object;  
    就是这么一个简单的数据结构,是怎么实现子节点和父节点的差别呢。比如说,现在我们需要对一个父节点的operate进行操作,此时的operate函数应该怎么操作呢?
  1. void operate_of_parent(struct _Object* pObject)  
  2. {  
  3.     int index;  
  4.     assert(NULL != pObject);  
  5.     assert(NULL != pObject->ppObject && 0 != pObject->number);  
  6.   
  7.     for(index = 0; index < pObject->number; index ++)  
  8.     {  
  9.         pObject->ppObject[index]->operate(pObject->ppObject[index]);  
  10.     }  
  11. }     
    当然,有了parent的operate,也有child的operate。至于是什么操作,那就看自己是怎么操作的了。

  1. void operate_of_child(struct _Object* pObject)  
  2. {  
  3.     assert(NULL != pObject);  
  4.     printf("child node!\n");  
  5. }  
    父节点也好,子节点也罢,一切的一切都是最后的应用。其实,用户的调用也非常简单,就这么一个简单的函数。

  1. void process(struct Object* pObject)  
  2. {  
  3.     assert(NULL != pObject);  
  4.     pObject->operate(pObject);  
  5. }  

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值