首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件开发 >

原来高焕堂也误用职责链模式解决方法

2012-02-17 
原来高焕堂也误用职责链模式近日 见同事正在看 高焕堂新书 《UML+OOPC 嵌入式C语言开发精讲》偶然发现他对CO

原来高焕堂也误用职责链模式
近日 见同事正在看 高焕堂新书 《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

[解决办法]
看看。
[解决办法]
代码不咋的,分析也不咋的

热点排行