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);
}
组合模式听说去很玄乎,其实也并不复杂。为什么?大家可以先想一下数据结构里面的二叉树是怎么回事。为什么就是这么一个简单的二叉树节点既可能是叶节点,也可能是父节点?
[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);
}
相关文章推荐
- 设计模式十二(组合模式,python语言实现)
- Go语言设计模式实践:组合(Composite)
- Java语言设计模式之组合模式(Composite)
- .NET中的设计模式三:组合模式
- 设计模式之Composite(组合)
- 简易模式脚本语言(PS)设计
- 窥视设计模式之组合模式(composite)
- 设计模式(10)-组合模式(Composite)
- 委托,语言级别的设计模式
- JUnit|测试驱动|组合设计模式
- Junit和ant集成及设计模式之组合模式
- 结构模式——设计模式之Composite(组合)[转载自http://www.jdon.com/]
- 设计模式c#语言描述——装饰(Decorator)模式
- 设计模式c#语言描述——建造者模式、适配器模式、合成(Composite)模式
- 设计模式袖珍版 连续转载之 - Composite(组合)
- 干净搞定delphi多语言-兼论设计模式
- .NET中的设计模式三:组合模式 选择自 lane_cn 的 Blog
- java设计模式之Composite(组合) (转)
- 委托,语言级别的设计模式
- 设计模式之Composite(组合)