连载:面向对象葵花宝典:思想、技巧与实践(35) - NOP原则
NOP。No Overdesign Priciple。不要过度设计原则。
这应该是你第一次看到这个原则。而且你也不用上网查了,由于这个不是大师们创造的,而是我创造的:)
之所以提出这个原则,是我自己吃过苦头,也在工作中见非常多人吃过相似的苦头。
你可能也见过这种场景:
产品提出了一个需求。设计师眼光非常长远,他甚至把5年后可能的业务变化都提出来而且加以设计了。让你不得不佩服设计师的高瞻远瞩的眼光。而且由衷的从心底赞叹:牛逼啊!
但非常快你就会发现。设计师是非常牛逼,但你开发的时候就非常苦逼了。设计方案巨复杂。工作量巨大,即使你发扬一不怕苦二不怕累的精神,每天加班加点奋斗了三个月最终做出来了,但你苦逼完了。測试跟着苦逼了:非常多东西測试都没办法測试!
怎么会出现这种情况呢?我们做面向对象不就是为了应对变化、拥抱变化么?
要回答这个问题事实上非常easy,孔夫子在《论语》中已经为我们解答了:“子贡问:‘师与商也孰贤?’子曰:‘师也过。商也不及。
’曰:‘然则师愈与?’子曰:‘过犹不及。’”
什么事情过头了就和没有达到是一样的效果,面向对象的设计也不例外。面向对象的初衷尽管是为了拥抱变化。但这个变化也是有一个度的,而不是预測得越长越好,原因非常easy:预測越长,预測的结果正确性越低!
谁能在2000年预測SUN公司的衰落?谁又能在2005年预測苹果的崛起?
除了预測时间越长准确性越差的问题外,过分设计会导致设计方案不必要的复杂、代码量庞大。投入产出不成正比,项目计划无法按时完毕。。。。。
。等等非常多问题。
有时候过分设计比设计不足的影响和危害更大,由于假设设计不足,我们还有“重构”这个利器。也不会出现浪费大量人力物力的情况。
而假设过分设计,假设后面发现原来的设计不对或者不合理,首先原有的投入浪费了,其次是即使重构,也须要花费很多其它的人力物力。
所以。在设计过程中要时刻谨记NOP原则,避免过度设计!
================================================
转载请注明出处:http://blog.csdn.net/yunhua_lee/article/details/35778577
================================================
连载:面向对象葵花宝典:思想、技巧与实践(35) - NOP原则的更多相关文章
- 连载:面向对象葵花宝典:思想、技巧与实践(28) - 设计原则:内聚&耦合
前面通过实例解说了一个一环扣一环的面向对象的开发流程:用例模型 -> 领域模型 -> 设计模型(类模型 + 动态模型),解答了面向对象怎样做的问题.接下来我们就要讲"怎样做好面向 ...
- IT第二十天 - 面向对象编程思想、抽象类、异常处理、程序操作日志记录、本周总结 ★★★
IT第二十天 上午 面向对象编程思想 1.组装电脑的设计: (1)电脑的组成:显示器+机箱 (2)机箱的组成:电源+主板+硬盘 (3)主板所包含的部件:cpu+内存+PCI接口+usb接口 (4)PC ...
- 黑马程序员——OC语言基础语法 面向对象的思想
Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结)(一)基础语法 1)关键字 @interface.@implementati ...
- Java面向对象的思想
面向对象的思想 1.面向对象的思想的特点: ①符合人们的日常思考习惯 ②能将复杂的问题简单化 ③将原来的执行者变为了现在的指挥者 面向对象的思想,所谓的对象,其实就是实体.对于实物的描述,通常有两个方 ...
- 面向对象编程思想(OOP)
本文我将从面向对象编程思想是如何解决软件开发中各种疑难问题的角度,来讲述我们面向对象编程思想的理解,梳理面向对象四大基本特性.七大设计原则和23种设计模式之间的关系. 软件开发中疑难问题: 软件复杂庞 ...
- U3D 飞机大战(MVC模式)解析--面向对象编程思想
在自己研究U3D游戏的时候,看过一些人的简单的游戏开发视频,写的不错,只是个人是java web 开发的人,所以结合着MVC思想,对游戏开发进行了一番考虑. 如果能把游戏更加的思想化,分工化,开发便明 ...
- OC - 1.面向过程和面向对象的思想对比
一.面向过程 1> 思想 面向过程是一种以过程为中心的最基础编程思想,不支持面向对象的特性. 面向过程是一种模块化程序设计方法 2> 开发方法 面向过程的开发方法是以过程(也可以说是模块) ...
- .net的自定义JS控件,运用了 面向对象的思想 封装 了 控件(.net自定义控件开发的第一天)
大家好!我叫刘晶,很高兴你能看到我分享的文章!希望能对你有帮助! 首先我们来看下几个例子 ,就能看到 如何 自定义控件! 业务需求: 制作 一个 属于 自己的 按钮 对象 ,然后 像 ...
- 面向对象编程思想(前传)--你必须知道的javascript
在写面向对象编程思想-设计模式中的js部分的时候发现很多基础知识不了解的话,是很难真正理解和读懂js面向对象的代码.为此,在这里先快速补上.然后继续我们的面向对象编程思想-设计模式. 什么是鸭子类型 ...
随机推荐
- Windows 10 UWP程序标题栏设置
在Windows 10程序中,以前只能用于全屏方式的Metro程序现在可以运行在窗口模式下了,并且改了个新名字,叫Windows 通用程序(Universal Windows app),简称UWP程序 ...
- DAC calibrates 4- to 20-mA output current
Industrial controls make heavy use of 4- to 20-mA current loops to transmit process measurements bec ...
- 初探Delphi中的插件编程
前言 我写Delphi程序是从MIS系统入门的,开始尝试子系统划分的时候采用的是MDI窗体的结构.随着系统功能的扩充,不断有新的子系统加入系统中,单个工程会变得非常大,每次做一点修改都要重新编译,单个 ...
- SqlServer收缩数据库语句
ALTER DATABASE [Spacebuilder] SET RECOVERY SIMPLEDBCC SHRINKDATABASE([Spacebuilder], 0)ALTER DATABAS ...
- NHibernate使用无状态Sessions
NHibernate 3.0 Cookbook第三章,Using stateless sessions的翻译. 当要处理大量的数据,你通常可能会使用更"底层"的API来改善性能,在 ...
- OpenERP实施记录(12):付款处理
本文是<OpenERP实施记录>系列文章的一部分. 1. 在前面的文章中,采购订单确认时自动生成了供应商发票,可以在 会计 > 供应商列表 > 供应商发票 查询,状态为&quo ...
- Unity接入谷歌支付
文章理由 前段时间负责Unity接入Google内购功能,一开始研究别人的技术博客时发现,他们的文章都有些年头了,有些细节的地方已经不像n年前那样了,技术永远是需要更新的,而这篇就作为2016年末的最 ...
- 【mybatis】mybatis访问报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 或者 feign被调用方使用的mybatis总报空指针异常java.lang.NullPointerException,而变量都没有问题的情况
mybatis访问报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 需要检查的步骤: ...
- 【spring cloud】spring cloud 使用feign调用,1.fallback熔断器不起作用,2.启动报错Caused by: java.lang.ClassNotFoundException: com.netflix.hystrix.contrib.javanica.aop.aspectj.Hystri解决
示例GitHub源码地址:https://github.com/AngelSXD/springcloud 1.首先使用feign调用,需要配置熔断器 2.配置熔断器需要将熔断器注入Bean,熔断器类上 ...
- Birt中实现字段拆分为表的还有一种方法
来源: http://developer.actuate.com/community/forum/index.php? /topic/36204-split-data-row/. 将字段拆分为 ...