19、C语言和设计模式(桥接模式)
2015-08-07 22:34
232 查看
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
在以往的软件开发过程中,我们总是强调模块之间要低耦合,模块本身要高内聚。那么,可以通过哪些设计模式来实现呢?桥接模式就是不错的一个选择。我们知道,在现实的软件开发过程当中,用户的要求是多种多样的。比如说,有这么一个饺子店吧。假设饺子店原来只卖肉馅的饺子,可是后来一些吃素的顾客说能不能做一些素的饺子。听到这些要求的老板自然不敢怠慢,所以也开始卖素饺子。之后,又有顾客提出,现在的肉馅饺子只有猪肉的,能不能做点牛肉、羊肉馅的饺子?一些只吃素的顾客也有意见了,他们建议能不能增加一些素馅饺子的品种,什么白菜馅的、韭菜馅的,都可以做一点。由此看来,顾客的要求是一层一层递增的。关键是我们如何把顾客的要求和我们的实现的接口进行有效地分离呢?
其实我们可以这么做,通常的产品还是按照共同的属性进行归类。
[cpp]
view plaincopy
typedef struct _MeatDumpling
{
void (*make)();
}MeatDumpling;
typedef struct _NormalDumpling
{
void (*make)();
}NormalDumpling;
上面只是对饺子进行归类。第一类是对肉馅饺子的归类,第二类是对素馅饺子的归类,这些地方都没有什么特别之处。那么,关键是我们怎么把它和顾客的要求联系在一起呢?
[cpp]
view plaincopy
typedef struct _DumplingReuqest
{
int type;
void* pDumpling;
}DumplingRequest;
这里定义了一个饺子买卖的接口。它的特别支持就在于两个地方,第一是我们定义了饺子的类型type,这个type是可以随便扩充的;第二就是这里的pDumpling是一个void*指针,只有把它和具体的dumpling绑定才会衍生出具体的含义。
[cpp]
view plaincopy
void buy_dumpling(DumplingReuqest* pDumplingRequest)
{
assert(NULL != pDumplingRequest);
if(MEAT_TYPE == pDumplingRequest->type)
return (MeatDumpling*)(pDumplingRequest->pDumpling)->make();
else
return (NormalDumpling*)(pDumplingRequest->pDumpling)->make();
}
在以往的软件开发过程中,我们总是强调模块之间要低耦合,模块本身要高内聚。那么,可以通过哪些设计模式来实现呢?桥接模式就是不错的一个选择。我们知道,在现实的软件开发过程当中,用户的要求是多种多样的。比如说,有这么一个饺子店吧。假设饺子店原来只卖肉馅的饺子,可是后来一些吃素的顾客说能不能做一些素的饺子。听到这些要求的老板自然不敢怠慢,所以也开始卖素饺子。之后,又有顾客提出,现在的肉馅饺子只有猪肉的,能不能做点牛肉、羊肉馅的饺子?一些只吃素的顾客也有意见了,他们建议能不能增加一些素馅饺子的品种,什么白菜馅的、韭菜馅的,都可以做一点。由此看来,顾客的要求是一层一层递增的。关键是我们如何把顾客的要求和我们的实现的接口进行有效地分离呢?
其实我们可以这么做,通常的产品还是按照共同的属性进行归类。
[cpp]
view plaincopy
typedef struct _MeatDumpling
{
void (*make)();
}MeatDumpling;
typedef struct _NormalDumpling
{
void (*make)();
}NormalDumpling;
上面只是对饺子进行归类。第一类是对肉馅饺子的归类,第二类是对素馅饺子的归类,这些地方都没有什么特别之处。那么,关键是我们怎么把它和顾客的要求联系在一起呢?
[cpp]
view plaincopy
typedef struct _DumplingReuqest
{
int type;
void* pDumpling;
}DumplingRequest;
这里定义了一个饺子买卖的接口。它的特别支持就在于两个地方,第一是我们定义了饺子的类型type,这个type是可以随便扩充的;第二就是这里的pDumpling是一个void*指针,只有把它和具体的dumpling绑定才会衍生出具体的含义。
[cpp]
view plaincopy
void buy_dumpling(DumplingReuqest* pDumplingRequest)
{
assert(NULL != pDumplingRequest);
if(MEAT_TYPE == pDumplingRequest->type)
return (MeatDumpling*)(pDumplingRequest->pDumpling)->make();
else
return (NormalDumpling*)(pDumplingRequest->pDumpling)->make();
}
相关文章推荐
- 18、C语言和设计模式(建造者模式)
- .h和.cpp的用法与区别
- C语言字符串,字符转数字,数字转字符(转)
- (C++)虚函数表解析(转)
- 17、C语言和设计模式(中介者模式)
- 16、C语言和设计模式(策略模式)
- C++中构造函数和析构函数
- 15、C语言和设计模式(适配器模式)
- 14、C语言和设计模式(装饰模式)
- C语言中的逻辑运算符
- c++之const,reference(引用),
- 今天一天都在忙论文的事情,所以今天没时间来学习c++,那就给大家带来一个简单小程序杨辉三角把
- 基于Gsoap 的ONVIF C++ 库
- 文件读写操作
- 13、C语言和设计模式(享元模式)
- C++字符数字的编码(Encode)与解码(Decode)
- 二叉树(C语言)
- C++ 中的封装、继承
- 标准C++中的string类的用法总结
- C++static成员的使用