浏览 5343 次
该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2007-01-22
指的是“某一个类受到多种变化的影响”,A/B/C/D……多种功能变化的时候它都需要修改。 病因大致是某个类负担了多项任务,太操心了。很可能需要再拆分几个类出来,把变化封装得更细。 以前我写代码的时候有一个例子,曾经有一段时间,P_Unit类处理所有BSC单元的逻辑,但各种单板的逻辑是不一样的,于是DTB改逻辑的时候要修改P_Unit、ABPM改的时候要修改P_UNit、甚至HDLC/UID等逻辑修改的时候P_Unit都要改。显然该类管得太多了。后来,我看了<重构>这本书,痛下决心做了重构。想起来03年,徐峰做配置CAF的时候建议我每个板子一个类,我完全不以为然。显然当初没有理解“封装变化”这四个字。 Shotgun Surgery(霰弹式修改) 指的是“一个变化引发多个类的修改”,完成某个需求的时候,A/B/C/D……多个类都需要修改。 病因大致是多个类之间的耦合太严重。很可能是类没有规划好,没有把变化封装得足够令人满意。 记得水手好像说过,去掉这个Bad Smell不好强求。也有些道理。而且举出Abstract Factory模式作为例证。 但我们要清楚的认识到我们努力的方向,Abstract Factory模式同样不完美,它没有满足Open-Close原则。我们可以在某些条件(包括技术条件)受限的时候写出不完美的代码,但一定要知道它是不完美的。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-01-22
你在java版面发的几篇文章,我都给隐藏了,原因是,你一次性发表相同类别的帖子过多,而且,帖子太短,最好是发一篇主贴,其他的内容以跟贴形式发表。
这次隐藏没有扣分,请重新编辑你的帖子后,再次发表。谢谢。 |
|
返回顶楼 | |
发表时间:2007-01-22
多谢提醒。
这些小体会是放这备份的,顺便选中了check box。hoho |
|
返回顶楼 | |