惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Threatpost
V
Vulnerabilities – Threatpost
TaoSecurity Blog
TaoSecurity Blog
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
G
GRAHAM CLULEY
S
Securelist
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
Arctic Wolf
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
WordPress大学
WordPress大学
Project Zero
Project Zero
T
Threat Research - Cisco Blogs
L
Lohrmann on Cybersecurity
C
Cyber Attacks, Cyber Crime and Cyber Security
F
Fortinet All Blogs
博客园 - 叶小钗
B
Blog RSS Feed
C
Cisco Blogs
Google DeepMind News
Google DeepMind News
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Apple Machine Learning Research
Apple Machine Learning Research
G
Google Developers Blog
K
Kaspersky official blog
D
Docker
Latest news
Latest news
Cisco Talos Blog
Cisco Talos Blog
T
Tor Project blog
Cyberwarzone
Cyberwarzone
Security Latest
Security Latest
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
Microsoft Azure Blog
Microsoft Azure Blog
C
Check Point Blog
J
Java Code Geeks
Simon Willison's Weblog
Simon Willison's Weblog
T
Tenable Blog
Recent Announcements
Recent Announcements
T
Tailwind CSS Blog
H
Help Net Security
L
LINUX DO - 热门话题
T
The Exploit Database - CXSecurity.com
Jina AI
Jina AI
S
SegmentFault 最新的问题
MyScale Blog
MyScale Blog
NISL@THU
NISL@THU
美团技术团队
腾讯CDC

博客园 - 太白飞仙

.Net网络资源 CI创意的方法与技巧 可控人生核聚变 用c#备份和还原sql server 2000数据库 论文先睹:关于科学的生命哲学的思考 蚂蚁造山的思考 语言争霸VS魔兽争霸 :: IT世界VS魔兽世界 第九章 SQL Server的简单应用 [导入]类型MSN窗体行为的实现(.NET 2.0) - 太白飞仙 - 博客园 [导入]文章藏金阁 [导入]敏捷实验室的一次争论 [导入]Netron研究(四)----"移动和联通"之联通篇 [导入]Netron研究(二)----"容器"登场 [导入]Netron研究(一)----初识 [导入]Netron研究(三)----"移动和联通"之移动篇 [导入]Agile Framework的日志服务 [导入]Agile Framework工作流服务的设计思路 [导入]WWF工作流引擎的一个奇怪现象 - 太白飞仙 - 博客园 [导入]时刻提防过度设计
[导入]KISS原则
太白飞仙 · 2006-01-16 · via 博客园 - 太白飞仙

Keep It Simple and Stupid!

简单设计敏捷开发中非常重要的一项实践,但是这条原则说起来简单却做起来难。因为每个程序员其实都是一个有完美主义的艺术家,所做软件其实都是一件自己的艺术品,同时受到许多关于设计方面的资料的影响,所以在做设计的时候会情不自禁的加上许多“优雅特性”和“灵活性”。

另一个很重要的原因在于,在产品推出后又不得不疲于应付客户频繁提出的许多新增加的需求的时候,会自然而然的想到:当时要是在做软件的时候能考虑到这些需求该多好啊,现在来改实在是太麻烦了。要是当初改的话,我只用添加几条代码就可以了。

其实这两种原因都能归结为一个:程序员希望自己所设计的系统能最大范围内适应变化!

这种想法的出发点是非常好的,可是在实际中却往往不是降低了工作量,反而增加了巨大的工作量。根本原因就在于:用户需求是无限量的,你永远也无法预测客户的需求变化。

举个形象一点的例子,用户真正的需求就好比是一个1000G甚至更大的硬盘,其大小仅仅只受用户想像力的约束。而根据软件技术的发展程度来看,你现在所做的程序很可能只是能满足了用户万分之一的需求,也就是100M左右。你为了让以后可能少开发一点程序,花了很多工夫做了个10M的缓存。可是你想想,10M VS 1000G,你的缓存命中率有多高?

即使不是做项目而是做产品,也不能妄自猜度用户的需求。一个好的产品的功能完善也是从初始的最简单版本开始,不断的从实际使用中接受用户的使用反馈,通过无数次的迭代而产生的。不可能有任何一个产品在第一个版本的时候,就凭着几个设计人员的想像,就把用户的需求考虑的面面俱到,完美无缺。

另外软件是一件非常讲究实效性和成本的产品,想推出最完美的产品当然没错,但是要考虑当我们在做这些“完美”产品的时候是否会加长实现的时间和成本代价。

道理说了一大堆,但是实际做起来就是非常难。Agilelabs Team内部在开发过程中也经常会讨论某项设计是否过度,有时候就连我自己其实也经常犯这样的错误。有时候回忆起自己当初洋洋自得的一些设计,确实有一些不必要的过度设计在里面。

过度设计的尺度很难把握,错误人人都会犯,犯错误没什么要紧的。但是关键在于是否有勇气推翻自己花了许多心血的劳动成果,做到这一点非常难,但这确实是我们开发人员的基本素质之一。据说John Carmak在写Doom的时候曾经整整全部重写了8遍代码,那时候还是用汇编,真是让人佩服。

程序员和项目经理的矛盾往往在于对技术方案的争论。程序员一般会按照自己的理想提出一个比较“完美”的设计方案,而项目经理则更加关心项目的完成时间。我现在更加深刻的理解项目经理的想法,同时我也是从一个程序员过来的,深知一个“设计方案”对项目的重要性。许多人说项目经理可以不懂技术,但是如果不懂技术怎么能评估“方案”的好处和实施成本?错误的否决一个优秀的技术方案和采纳一个错误的技术方案都会对项目产生致命的影响。项目经理责任重大啊!

扯远了点。任随思维的跳跃,随手写了这许多,算是对今天关于权限系统设计讨论的一个心得记录。

今天讨论中我提出的一个简单设计的原则就是:只添加目前需要用到的代码,目前不用的代码就不要写,等到以后要用的时候再写。

希望敏捷实验室能在一次次的讨论中提高自己根据技术方案结合项目的进展要求情况,能综合各种因素提高对设计尺度的把握能力。


文章来源:http://www.agilelabs.cn/blogs/linkin/archive/2006/01/02/450.aspx