原来高焕堂也误用职责链模式

wanglovec 2010-01-05 09:32:59
近日 见同事正在看 高焕堂新书 《UML+OOPC 嵌入式C语言开发精讲》偶然发现他对COR模式存在严重误解。

废话少说 ,具体如下:

在他的大作 32.5 章节里 用到该模式



代码如下:

#include "lw_oopc_kc.h"
#include "ex32-il.h"

CLASS(LED_P0)
{
IMPLEMENTS(IL);
void (*init)(LED_P0*);
IL* next;
};

CLASS(LED_P1)
{
IMPLEMENTS(IL);
void (*init)(LED_P1*);
IL* next;
};

CLASS(LED_P2)
{
IMPLEMENTS(IL);
void (*init)(LED_P2*);
IL* next;
};



/* EX32-led.c */
#include <REG51F.H>
#include "lw_oopc_kc.h"
#include "ex32-led.h"

static void init_1(LED_P1* t) {
t->next = NULL;
// xxx = 0xf3;
}

static int pass_1(char ty, char hx, void *t) {
LED_P1 *cthis = (LED_P1*)t;
IL* ps = cthis->next;
if(ty=='1')
{
P1 = hx;
return 1;
}
if(ty=='A') P1 = hx;
if(ps == NULL) return 0;
else return ps->pass(ty, hx, ps);
}


CTOR(LED_P1)
FUNCTION_SETTING(init, init_1)
FUNCTION_SETTING(IL.pass, pass_1)
END_CTOR
// -------------------------------
static void init_0(LED_P0* t) {
t->next = NULL;
}

static int pass_0(char ty, char hx, void *t) {
LED_P0 *cthis = (LED_P0*)t;
IL* ps = cthis->next;
if(ty=='0')
{
P0 = hx;
return 1;
}
if(ty=='A') P0 = hx;
if(ps == NULL) return 0;
else return ps->pass(ty, hx, ps);
}

CTOR(LED_P0)
FUNCTION_SETTING(init, init_0)
FUNCTION_SETTING(IL.pass, pass_0)
END_CTOR
//----------------------------------------
static void init_2(LED_P2* t) {
t->next = NULL;
}

static int pass_2(char ty, char hx, void *t) {
LED_P2 *cthis = (LED_P2*)t;
IL* ps = cthis->next;
if(ty=='2')
{
P2 = hx;
return 1;
}
if(ty=='A') P2 = hx;
if(ps == NULL) return 0;
else return ps->pass(ty, hx, ps);
}


CTOR(LED_P2)
FUNCTION_SETTING(init, init_2)
FUNCTION_SETTING(IL.pass, pass_2)
END_CTOR







这三个类 就是职责链中的负责处理请求与转发请求的类,但 严重问题是 他们与 请求基本存在一一对应的关系

if(ty=='0')
{
P0 = hx;
return 1;
}

这是LED_P0的责任, 如果 把'0'换为'1' 则就是 LED_P1的责任 这是我们从代码里发现的, 其实他自己在书里也已经写了(如果ty值为'0',表示这是LED_P0的责任,于是将另一个参数hx值送到P0。如果ty值为'A',表示这是所有对象的都有的责任,。。)



结论:高焕堂完全误解了COR模式 ,其实这些代码散发着 重复的臭味 完全可以重构到表模式 具体如何重构 不用我说了吧??



摘自这本书的高焕堂简介:

从事IT行业近30年,被称为“台湾OO技术教父级代表人物”;近年来,专注与产业 企业及嵌入式产品的架构设计,被称为

“台湾软件架构设计大师”。。。。。

http://www.cnblogs.com/wangok/archive/2010/01/05/1639388.html
...全文
68 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
看看。
夭夭 2010-01-05
  • 打赏
  • 举报
回复
代码不咋的,分析也不咋的

3,405

社区成员

发帖
与我相关
我的任务
社区描述
专题开发/技术/项目 设计模式
社区管理员
  • 设计模式
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧