反模式(英文:Anti-patterns或pitfalls), 是指用来解决问题的带有共同性的不良方法。它们已经经过研究并分类,以防止日后重蹈覆辙,并能在研发尚未投产的系统时辨认出来。
软件开发中公认的反模式
项目管理上的反模式
水中望月(Smoke and mirrors):向人演示还没有实现的功能看上去会是什么样的。英文缘自一项魔术手法:放出烟雾并趁机用镜子遮住一件物体,使它看起来像是消失了。
软件膨胀:随着版本的升级,软件越来越消耗系统资源。
不良管理︰在未对主题有足够认识的情况下管理一个专案。
一般设计上的反模式
反抽象:需要的功能并不暴露给用户,导致用户要在较高层次重新实现一些功能。
四不像:往往一个设计模型可以暴露不同的接口给用户,不同的接口表现了模型的不同方面。然而把不同方面的功能混在一起是常见的不良设计。
乱麻球:系统没有可辨认的结构,就像一团乱麻一样。
万应灵:一个对象了解的东西太多,或者要做太多的事情,就好像无所不能一样。
屠龙术:没有必要的复杂设计。
竞争危害(Race Hazard): 缺乏预见事件以不同顺序发生的后果。
面向对象设计上的反模式
万能类︰在一个类的设计中,聚集了太多的函数。
吵闹鬼︰建立某对象的目的只是为了传送讯息给其它的物件。
溜溜问题︰因结构(例如继承)极度破碎冗长,而必须花费极大力气来了解它。
编程上的反模式
硬编码(Hard Code):或称写死。在实现某系统用途上设死该系统的运作环境。
紊乱代码︰几乎无法理解的结构,特别是因为代码结构的滥用。
超布尔逻辑︰不必要的比较,或是过于抽象的布尔计算。
无用的例外处理︰插入了条件去防止运行时异常,但确在条件为false时又throw(例如:if A not null then process (A) else throw null-exception endif).
方法上的反模式
剪贴编程(Copy-n-paste programming):宁愿拷贝(并修改)现存代码而非创造通用的解决方案。
反重构: "移除功能性并以注解取代"的过程。
金锤子: 假设个人偏好的解决方案是世界通用。
掩耳盗铃: 假设一个已知的bug不会出现。
不成熟的优化: 根据不足信息优化。
重新造个轮子: 拒绝采纳现有的解决方案,重写一个。
造了个正方形的轮子: 当一个优秀的方案存在时,创造一个蹩脚解决方案。
结构管理上的反模式
相依性地狱:由于需要的产品版本不匹配造成的种种问题,特别是在UNIX/Linux。
DLL地狱:由于动态连接库的版本、存在与否、和重复所造成的种种问题,特别是在Microsoft Windows。
JAR地狱:源自于不同版本或位址的JAR档案所造成的问题,常造成加载模组的欠缺。
延伸冲突︰源自于Mac OS不同的延伸尝试修补相同的系统部分。
一些组织方面的反模式
分析麻痹症:项目分析过程已经长得不成比例,却听之任之。
摇钱树项目:或者叫吃老本,一件有利可图的产品让新产品固步自封。
永远革命:总是要不停地不计代价将现有系统移植到新的环境。
军队式管理。没有容忍异议的空间。
Scope creep: 允许专案范围增长而没有适当控制
分享到:
相关推荐
J2EE反模式.pdf 是关于java的一种反模式
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的设计。本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的设计。本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的设计。本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的没计:本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的没计:本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的没计:本书的目的不是想指导开发人员如何完成...
本书不仅指出了许多J2EE开发中存在的反模式及其症状和引发的后果,而且分析了其产生的原因,并至少给出了一种重构方案,指导开发人员逐步转换代码实现,从而得到更好的没计:本书的目的不是想指导开发人员如何完成...
反模式是不推荐的做法,它们可能在特定情况下看似有效,但长期来看会导致代码的脆弱性和维护困难。 在整个文档中,还穿插着一些实际案例的介绍,比如宾馆订房管理系统,以及城市休假订票应用程序等,这些案例提供了...
J2EE(Java 2 Platform, Enterprise Edition)是一个广泛使用的平台,用于构建企业级应用,因此J2EE反模式尤其值得关注,因为它们直接影响到应用的稳定性和效率。 首先,让我们深入了解架构模式。这些模式包括分层...
本书《J2EE反模式》(英文原版)由Bill Dudney、Stephen Asbury、Joseph K. Krozak 和 Kevin Wittkopf 联合编写,出版社为John Wiley & Sons,于2003年8月11日首次出版,全书共624页。 版权信息显示,本书版权所有...
1. **J2EE反模式**:J2EE作为企业级应用开发的平台,其复杂性可能导致许多反模式的出现。例如,过度使用EJB(Enterprise JavaBeans)可能导致性能下降,因为EJB容器的管理成本较高;不恰当的会话bean使用,如过多...
反模式 J2EE与设计模式 J2EE模式的问题域 小结 第2章 Web层设计模式 表示模式 案例:宾馆订房管理系统 标识模式 小结 第3章 持久性框架设计模式 开始模型 何谓持久性框架 TitleDAO会话Bean Value Object模式 ...
10. **J2EE反模式**:在J2EE应用开发中,过度使用EJB、Session Beans等技术可能导致性能下降,复杂度增加。理解微服务、轻量级框架(如Spring Boot)的优势,并根据项目需求选择合适的技术栈。 阅读《Java 反模式 ...
J2EE反模式同样是一个重要的学习领域,特别是在大型企业级应用开发中。"Session Bean Eager Fetching"反模式是一个例子,它指出过度使用EJB会话bean的ejbLoad()方法可能会导致不必要的数据库查询,从而影响性能。...
J2EE反模式部分则专门关注企业级Java应用开发中的陷阱。J2EE平台提供了丰富的功能,如EJB、Servlet、JSP等,但如果不恰当使用,可能会导致应用变得笨重、难以维护。例如,滥用EJB可能会增加不必要的复杂性,而过度...