Keep It Simple and Stupid, 就是KISS原则. 简单是软件设计之美, 简单的设计使得软件产品易于开发, 易于维护. 简单代表着高质量, 少加班, 每个人都希望自己的工作是简单的.
在KISS原则之外, 应该有一个更重要的原则: Useful. 满足需求是一切产品的低限. 也许需求本身也应该KISS, 简单的需求意味着底成本, 高效率. 可惜客户有时候很难克制自己的欲望. 也许站在客户角度看见的KISS和我们开发者眼中的KISS不完全是一个概念. 有人说: 好的设计是客户做出来的, 开发者其实只是在帮助客户做设计.
Keep It Simple and Stupid, 最难的在于Keep. 一个人做一个Simple的设计并不难, 难的是让这个设计在需求变化的过程中保持简单. Keep是关键, Keep的时间就是这个设计的生命. 当一个产品无法再Keep Simple的时候, 维护就变的越来越困难, 渐渐的无法加入任何变化, 他的生命也就快结束了. 升级意味着重新做一个.
Keep Simple就是要抵抗需求的变化, 一开始的需求总是比较简单, 比如这样: 设计一个汽车驾驶程序, 他会在遇到红灯的时候停下来, 绿灯的时候向前进.
方案一:
这是一个简单的需求, 给出的解决方案也很简单. But, 如果遇到这样的情景: 红灯已经亮了, 但是车前面有个人正在过马路, 他走的很慢. 这个时候当然不能go, 应该按响车喇叭, 等他走过去. 方案一必须要修改:
现实的情况仍然可能发生变化, 比如: 前面尽管是绿灯, 但是横向路口一辆救护车开过来, 或者前面有一个路牌"道路维修请绕行"......种种情况, 其结果就是要在原来的if-else里面加上一个新的判断.
这是一个Simple的设计, 但是很难Keep Simple. 当这个代码片断不断增加, 长度突破500行的时候, 任何相关的需求变更都是一场恶梦. 在软件开发中更复杂的情况我想大家都遇到过.
方案二:
想象有一个叫做策略的东西, 他有下面的特征: 他有一个名称, 一个优先级, 他可以判断某种情景, 返回在这个情景中应该采取的行为. 红灯停, 绿灯行, 有人在前面要按喇叭, 都是具体的策略. 就是下面这个结构:
还应该有一个Action, 代表策略判断后应该采取的行为. 前进, 停止, 按喇叭都是具体的行为, 这样的结构:
最后的程序运行过程就是这样: 先初始化一个stratage list, 将需要判断的策略都放在里面. 在需要的地方一一判断这些策略, 执行优先级最高的策略所返回的行动就可以了.
这样的设计, 随着需求的变化, 策略日益复杂, 只要添加新的stratage, 赋予合适的优先级, 再视情况派生新的action就可以了. 程序的复杂程度不会随之增加.
Quick & Dirty vs 过度设计
设计应该始于简单, 保持简单. 作出一个简单的设计, 当需求发生变化, 首先应该做的就是重构设计, 使之重新变得简单, 然后再加上新的功能. 简单不是quick and dirty. 简单的东西也许会变得复杂, 复杂的东西也许本质上是更加的简单. 这首先需要对需求充分的理解, 当然还有一点点的技巧. 过分的设计也是一个问题, 但是考虑一下维护人员的痛苦, 一个过度设计的系统通常要比一个quick and dirty的系统更加便于维护.
分享到:
相关推荐
KISS原则(Keep It Simple and Stupid),强调简洁明了的设计;以及FAB原则(Features, Advantages, Benefits),即突出产品的特性、优势和对消费者的益处,这些都是提升视觉营销效果的关键。 课程中的3C商品视觉...
KISS原则(Keep It Simple and Stupid),意在保持设计简洁,避免过多的文本、过渡和动画,以免分散观众注意力。 在实际操作中,要充分利用母板和模板,定制配色方案,保存自己的模板以备后用。文字应用时,标题应...
在优化方法的选择上,应遵循适用性、理解性、易实现性和KISS原则(Keep It Simple and Stupid)。人工神经网络模型被广泛应用于物流量预测,通过预处理、分组、训练、预测和还原等步骤,构建出适应物流系统复杂性的...
在进行PPT设计时,遵循"KISS"原则至关重要,即“Keep It Simple and Stupid”。这意味着在创建PPT时,应保持内容清晰简洁,避免过于复杂的设计。首先,确定演示的主题,列出大纲,确保主要观点和关键词之间的逻辑...
KISSY(Keep It Simple and Stupid)这个名字本身就蕴含了其设计理念——保持简单,注重实用。作为一个JavaScript库,KISSY集成了模块化、事件系统、DOM操作、Ajax通信等多种功能,旨在为前端开发者提供一套全面而...
2. **明确讯息**:保持内容简洁明了,遵循KISS原则(Keep It Simple and Stupid),避免无关信息。 3. **构建大纲**:预先规划演示文稿的结构,列出关键观点和关联。 4. **创意设计**:利用图表、动画等视觉工具辅助...
KISSY的核心理念是“Keep it Simple and Stupid”,即保持简单和愚蠢,这体现在其设计理念上,力求提供简洁易用的API,让开发者可以快速构建复杂的前端应用。KISSY支持AMD(Asynchronous Module Definition)模块...
8. **KISS原则**:保持简单愚蠢(Keep It Simple and Stupid),设计应直观易懂,避免复杂性。 9. **听众原则**:设计PPT时要充分考虑听众的需求,让他们既能听懂也能看懂,确保信息传达的有效性。 10. **“恶心”...
1. KISS原则(Keep It Simple and Stupid),强调简报要简洁明了,避免复杂的图表和文字。 2. Magic Seven原则,指的是人们更易记住七项信息或者概念,所以尽量将关键信息归纳为七条。 3. VISO timelines,可能是指...
- KISS(Keep It Simple and Stupid):保持设计简单,避免过度设计。 - Performance is all about code path:性能优化的核心在于代码路径的优化。 三、优化实践 1. 要牛篇:优化响应时间,例如对比SSD与HDD的...
表达同样重要,应确保信息简洁明了,遵循KISS原则(Keep It Simple and Stupid),避免使用可能导致歧义的复杂表述。同时,肢体语言在沟通中占有很大比例,它能够传达55%的信息,远超过语言和声调的总和。因此,要...
1. **KISSY框架**:KISSY的核心理念是"Keep It Simple and Stupid",它提供了一种简单易用的方式来组织和管理JavaScript代码,支持AMD(Asynchronous Module Definition)模块加载机制,使得代码可以按需加载,提高...
- **KISS原则**:Keep It Simple and Stupid,即保持简洁。先规划好大纲,明确主要观点,再用图表、动画等视觉工具辅助说明。 - **文字使用**:遵循Magic 7原则,每页内容控制在5至9行之间,保持信息的精炼。 - *...
1. **KISS原则**:保持简报简单且直白(Keep It Simple and Stupid)。在设计简报时,遵循这一原则,避免过多复杂的细节,使内容易于理解。 2. **内容规划**:首先确定主题,列出大纲,将主要观点和关键字关系构建...
KISS是“Keep It Simple and Stupid”的缩写,它要求我们在创作或设计时,尽可能地减少复杂性,简化过程。这个原则强调,简单的设计往往能够更加直接地传达信息,更容易被受众理解和接受。在设计领域,尤其是在PPT...
"Kiss"在外汇EA领域通常代表“Keep It Simple and Stupid”,暗示这个EA的设计理念是简洁高效,可能采用了一种简单的交易逻辑。 【描述】"most powerfull EA scalping mt5" 描述了这个EA的特性,它被称为最强大的MT...
文档中提到的KISS原则(Keep It Simple and Stupid,保持简单和笨拙),提醒用户在处理复杂数据和报表时,应追求简单明了的解决方案,避免过度复杂化,这是保证工作效率和数据准确性的重要原则。 文档的技巧与思路...
2. **KISS原则**:保持简单愚蠢(Keep It Simple and Stupid)。PPT的目标是让大众易于理解,而不是展示个人的专业深度。避免过于复杂,确保内容通俗易懂,这样才能有效传达你的观点。 3. **10/20/30法则**:演示...
7. **程序设计原则**:书中可能会介绍一些重要的编程原则,如DRY(Don't Repeat Yourself,不要重复自己)、KISS(Keep It Simple and Stupid,保持简单和愚蠢)、SOLID(单一职责、开闭原则、里氏替换、接口隔离、...