码迷,mamicode.com
首页 > 其他好文 > 详细

【转】需求到代码的距离

时间:2015-07-25 21:21:48      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:

需求到代码的距离有多远?也许很近,就在转角的街区,也许很远,就像6级专家与1级编码工的距离,取决于你的代码是如何实现的。


先来看一个简单的需求:网口状态down时删除路由表项。
非常简单的一种实现:
int link_down()
{
do_something();

delete_route(); //删除路由
}


需求与代码的距离如此之近,近的来不及反应就扑面而来。


不久,另外一个模块的人找你来了,说在网口状态down的时候也要把arp表项删除,希望在link_down接口里调用下delete_arp。


没问题,你非常快速的完成了功能,获得了大家的掌声与赞赏。
int link_down()
{
do_something();

delete_route(); //删除路由表项

delete_arp(); //删除ARP表项
}




再来看另外一个稍有经验的人是怎么想着:要是再有其他模块想要在link down的时候做点事情,要我添加代码,岂不烦死了。
于是,他开发了一个注册回调通知的代码,放在link模块,由于代码较多,耗时较长,他被项目经理和ARP模块的人骚扰了好几回。他完成后的代码如下:
struct link_notify
{
int (*notify_func)(void *, unsigned long);
unsigned long para;
struct link_notify *next;
};


struct link_notify *link_notify_head;


int link_notifier_register(struct link_notify *notify)
{
notify->next = link_notify_head;
link_notify_head = notify;
return 0;  
}


int link_down()
{
do_something();

link_list = link_notify_head;
while(link_list)
{
link_list->notify_func(para); // 调用注册的通知函数

link_list = link_list->nexxt;
}
}
代码完成后,他酷酷的对ARP模块的人说,你要就自己注册吧,别来烦我。


还有另外一个他,想着既然link down的时候需要通知很多模块处理信息,那么在link up的时候也是需要通知很多模块处理很多信息,还有其他很多事件状态变化也需要通知。于是,他把notify从link模块移出来,变成了一个独立的小模块。怎么移出来,参考另外一篇文章:《一种典型C语言开发思维及其可能的问题》






还有另外一个他,想着既然事件通知这种机制很多地方都使用到了,那能不能归类总结一下,作为一个通用的解决方案呢,于是,他把事件通知总结为一种设计模块,他是谁?他就是GOF( 《设计模式》一书的4个作者)。




需求到代码的距离,取决于你是谁,怎么实现你的代码。

【转】需求到代码的距离

标签:

原文地址:http://www.cnblogs.com/littleKing163/p/4676557.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!