设计模式和反模式简单介绍

作为一个资深开发人员,大家都应该听说过设计模式(design pattern),但是不是所有的人都听说过反模式(anti-pattern)。今天我们就来谈谈后者,何为反模式。

成都创新互联公司是创新、创意、研发型一体的综合型网站建设公司,自成立以来公司不断探索创新,始终坚持为客户提供满意周到的服务,在本地打下了良好的口碑,在过去的十年时间我们累计服务了上千家以及全国政企客户,如成都资质代办等企业单位,完善的项目管理流程,严格把控项目进度与质量监控加上过硬的技术实力获得客户的一致赞美。

谈反模式之前当然先要谈谈何为设计模式,因为两者是紧密联系在一起的。从我个人的理解认为,设计模式是一种在前人的设计经验上总结出来的对于一些普遍存在的问题提供的通用的解决方案。这些设计模式已经经过了长时间的实际应用和验证,被证实是有效可行的解决方案。通过使用设计模式,我们可以获得以下优势:

1.       开发小组不需要重新设计解决方案来解决已经被前人解决过的问题。如此可以节省很多设计开发时间。

2.       当开发小组讨论设计的时候,使用设计模式可以使大家更好了理解问题所在和解决方案,而且对解决方案有一个比较统一的认知。

3.       设计模式本身已经通过了大量的实际运用和验证,其设计质量和实用价值有很好的保证。

4.       设计模式本身有健全的文档,可以一定程度上简化撰写开发文档。


在开发过程中,使用设计模式对系统/软件开发有很多其他的优点,这里就不一一列举了。一些常用的设计模式包括:单列模式,工厂模式,修饰模式,策略模式,代理模式等等。有兴趣的朋友可以看下“四人帮”的设计模式这本书“Design Patterns: Elements of Reusable Object-Oriented Software,其他还有大量讨论设计模式的书籍,比如“Head First Design Pattern”,  “The Design Patterns Java Workbook” 等等


简单的谈完了设计模式,我们来谈一下重点,什么是反模式。很多人对反模式有一个理解误区,有人认为反模式是由于将通常使用的设计模式用在了错误的地方,也有人认为反模式只是一种坏习惯。简单的来说,反模式是指在对经常面对的问题经常使用的低效,不良,或者有待优化的设计模式/方法。甚至,反模式也可以是一种错误的开发思想/理念。在这里我举一个最简单的例子:在面向对象设计/编程中,有一条很重要的原则, 单一责任原则(Single responsibility principle)。其中心思想就是对于一个模块,或者一个类来说,这个模块或者这个类应该只对系统/软件的一个功能负责,而且该责任应该被该类完全封装起来。当开发人员需要修改系统的某个功能,这个模块/类是最主要的修改地方。相对应的一个反模式就是上帝类(God Class),通常来说,这个类里面控制了很多其他的类,同时也依赖其他很多类。整个类不光负责自己的主要单一功能,而且还负责了其他很多功能,包括一些辅助功能。很多维护老程序的开发人员们可能都遇过这种类,一个类里有几千行的代码,有很多功能,但是责任不明确单一。单元测试程序也变复杂无比。维护/修改这个类的时间要远远超出其他类的时间。很多时候,形成这种情况并不是开发人员故意的。很多情况下主要是由于随着系统的年限,需求的变化,项目的资源压力,项目组人员流动,系统结构的变化而导致某些原先小型的,符合单一原则类慢慢的变的臃肿起来。最后当这个类变成了维护的噩梦(特别是原先熟悉的开发人员离职后),重构该类就变成了一个不容易的工程。

作者华杰, 从事IT工作15年,做过程序员,首席软件工程师,架构师,IT技术顾问,现为澳大利亚移民和边境保护局Tech lead.

LinkedIn:http://au.linkedin.com/in/jie-hua-01021118
个人电子邮件:jhua04@outlook.com


当前题目:设计模式和反模式简单介绍
网页URL:http://ybzwz.com/article/ihisec.html

其他资讯