什么是敏捷设计

Jack Reeves说,

实际上满足工程设计标准的惟一软件文档,就是源代码清单

设计的臭味——腐化软件的气味

当软件出现下面任何一种气味时,就表明软件正在腐化。

  • 僵化性(Rigidity):很难对系统进行改动。
  • 脆弱性(Fragility):对系统的改动会导致系统中和改动的地方在概念上无关的许多地方出现问题。
  • 牢固性(Immobility):可重用性弱。很难解开系统的纠结,使之成为一些可在其他系统中重用的组件。
  • 粘滞性(Viscosity):做正确的事情比做错误的事情要困难。
  • 不必要的复杂性(Needless Complexity):设计中包含有不具任何直接好处的基础结构。
  • 不必要的重复(Needless Repetition):设计中包含有重复的结构,而该重复的结构本可以使用单一的抽象进行统一。
  • 晦涩性(Opacity):很难阅读、理解。没有很好地表现出意图。

在非敏捷环境中,由于需求没有按照初始设计预见的方式进行变化,从而导致了设计的退化。 通常,改动都很急迫,并且进行改动的开发人员对于原始的设计思路并不熟悉。因因而,虽然对设计的改动可以工作,但是它却以某种方式违反了原始的设计。随着代码改动的进行,这些违反渐渐积累,设计开始出现臭味。

如果我们的设计由于持续、大量的需求变化而失败,那就表明我们的设计和实践本身是有缺陷的。我们必须要找到一种方法,使得设计对于这种变化具有弹性,并且应用一些实践来防止设计腐化。

敏捷团队不允许软件腐化

基本不预先设计,通过需求变化来保持活力。保持系统设计尽可能的干净、简单,使用单元测试和验收测试作为支持。利用灵活性,持续改进设计。

每次需求变更导致设计不再具备灵活性时,就改造原有设计,而不是对原有设计进行打补丁,以满足最新需求,并更具备灵活性。

敏捷开发人员知道要做什么,是因为:

  1. 他们遵循敏捷实践去发现问题
  2. 他们应用设计原则去诊断问题,并且
  3. 他们应用适当的设计模式去解决问题。

软件开发的这三个方面间的相互作用就是设计。

结论

敏捷设计是一个过程,不是一个事件。它是一个持续的应用原则、模式以及实践来改进软件的结构和可读性的过程。它致力于保持系统设计在任何时间都尽可能的简单、干净以及富有表现力。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,540评论 25 708
  • 但凡有点追求的PM,对产品都会长久保持高涨的热爱,这种状态,丝毫不亚于二十一二岁小伙儿对姑娘的那种情感,真挚又强烈...
    杨夏阅读 566评论 0 0
  • 初秋肃杀百花残,月下半弦,天向谁边。病去如同抽丝茧。 疼痛仍觉五更寒,述说凄惨。无人可怜。又是一夜冷无眠。
    横出的虫阅读 244评论 1 3
  • 各位来自五湖四海的听众们大晚上好,欢迎来到荔枝FM1074372的电台广播,我是你们的主播AJ。今天是2017年3...
    脑筋吉转弯阅读 693评论 0 0
  • 人到中年的几个特征 1、午休成为工作的一部分,被子成为办公室的标配,觉得中午约饭局的人都是扯淡。午睡也要打呼噜,而...
    AA阳光灿烂阅读 120评论 0 0