免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3395 | 回复: 0

总结软件开发中的几个原则 [复制链接]

论坛徽章:
0
发表于 2007-09-02 08:48 |显示全部楼层
最近刚看完《设计模式解析》一书,总结一下书中阐述的软件设计原则:

  • 开闭原则(open-closed principle):模块、方法和类应该对扩展开放,对修改封闭。也就是说,好的软件设计应该是不对已有代码进行修改就能扩展功能的。开闭原则本质上意味着将软件设计成为新功能能够作为单独模块加入系统,这样就尽可能的降低了集成的成本。
  • 依赖倒置原则(dependency inversion principle):高层模块不应该依赖于低层模块,而是都应该依赖于抽象。而抽象,不应依赖于细节,细节应该依赖于抽象。这一原则的隐寓是使用对象和被使用对象之间只能在概念层次存在依赖,而非实现层次。
  • LISKOV原则:一个从基类派生的类应该支持基类的所有行为。这一原则可以扩展为:让使用对象甚至无法知道是否存在派生类。也就是说,对于给定的基类(或者接口)的引用,使用对象无法知道其是否存在派生类(或者实现类)。因此所有这些派生类(或者实现类)都是可以互换的,从而对类型进行了很好的封装。实践中这意味着子类型不应该在基类型的公开接口中添加新的公开方法。这还意味着基类型必须是所建模的概念的完整规格说明。

除了这三大原则之外,还有一些解释性的小原则:

  • 针对接口编程,而不是针对实现编程。
  • 优先使用对象组合,而不是类继承。
  • 封装变化。考虑什么能够在不引起重新设计的前提下改变。
  • 不要把对象的使用和对象的创建/管理放在一起。对于系统中的任意两个实体A和B,应该将它们之间的关系限制为A使用B,或者A创建/管理B, 但是两种关系永远不用同时存在。

注:LISKOV原则是Barbara Liskov在1988的著作《Data Abstraction and Hierarchy》中提出的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP