您可以捐助,支持我们的公益事业。

1元 10元 50元





认证码:  验证码,看不清楚?请点击刷新验证码 必填



  求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Model Center   模型库  
会员   
   
DeepSeek大模型应用开发实践
6月12-13日 厦门
基于 UML 和EA进行分析设计
6月23-24日 北京+线上
人工智能、机器学习 TensorFlow+Keras
6月30日-7月1日 直播
     
   
 
 订阅
面向对象设计原则
 
作者:唐锡晋
  43  次浏览      27 次
 2005-8-30
 
编辑推荐:
-本文对CORBA、DCOM 和Java 等三种典型的构件模型做出了比较分析,希望对您的学习有所帮助。
本文来自于摘抄自《敏捷软件开发-原则、方法与实践》-Robert C. Martin,由火龙果软件Linda编辑、推荐。

(1)SRP 单一职责原则

就一个类而言,应该仅有一个引起它变化的原因。

职责即为"变化的原因".

(2)OCP 开放封闭原则

软件实体(类、模块、函数等)应该是可以扩展的,但是不可修改。

对于扩展是开放的,对于更改是封闭的.

关键是抽象.将一个功能的通用部分和实现细节部分清晰的分离开来.

开发人员应该仅仅对程序中呈现出频繁变化的那些部分作出抽象.拒绝不成熟的抽象和抽象本身一样重要.

(3)LSP Liskov替换原则

子类型必须能替换掉他们的基本类型

(4)DIP 依赖倒置原则

抽象不应该依赖于细节。细节应该依赖于抽象。

Hollywood原则: "Don't call us, we'll call you".程序中所有的依赖关系都应该终止于抽象类和接口。针对接口而非实现编程。

任何变量都不应该持有一个指向具体类的指针或引用。

任何类都不应该从具体类派生。

任何方法都不应该覆写他的任何基类中的已经实现了的方法。

(5)ISP 接口隔离原则

不应该强迫客户依赖于他们不用的方法。接口属于客户,不属于他所在的类层次结构。

多个面向特定用户的接口胜于一个通用接口。

(6)REP 重用发布等价原则

重用的粒度就是发布的粒度.

(7)CCP 共同重用原则

一个包中的所有类应该是共同重用的。如果重用了包中的一个类,那么就要重用包中的所有类。

相互之间没有紧密联系的类不应该在同一个包中。

(8)CRP 共同封闭原则

包中的所有类对于同一类性质的变化应该是共同封闭的。一个变化若对一个包影响,则将对包中的所有类产生影响,而对其他的包不造成任何影响.

(9)ADP 无依赖原则

在包的依赖关系中不允许存在环.

细节不应该被依赖.

(10)SDP 稳定依赖原则

朝着稳定的方向进行依赖.

应该把封装系统高层设计的软件(比如抽象类)放进稳定的包中,不稳定的包中应该只包含那些很可能会改变的软件(比如具体类)。

(11)SAP 稳定抽象原则

包的抽象程度应该和其他稳定程度一致.

一个稳定的包应该也是抽象的,一个不稳定的包应该是抽象的.

(12)DAP(Default Abstraction Principle)缺省抽象原则

在接口和实现接口的类之间引入一个抽象类,这个类实现了接口的大部分操作.

(13)IDP(Interface Design Principle)接口设计原则

规划一个接口而不是实现一个接口。

(14)BBP(Black Box Principle)黑盒原则

多用类的聚合,少用类的继承。

(15)DCSP(Don't Concrete Supperclass Principle)不要构造具体的超类原则

避免维护具体的超类。

   
43 次浏览       27


最新活动计划
DeepSeek大模型应用开发 6-12[厦门]
人工智能.机器学习TensorFlow 6-30[直播]
基于 UML 和EA进行分析设计 6-23[北京]
嵌入式软件架构-高级实践 7-9[北京]
用户体验、易用性测试与评估 7-25[西安]
图数据库与知识图谱 8-23[北京]
 
 
最新文章
iPerson的过程观:要 过程 or 结果
基于模型的需求管理方法与工具
敏捷产品管理之 Story
敏捷开发需求管理(产品backlog)
Kanban看板管理实践精要
最新课程
基于iProcess的敏捷过程
软件开发过程中的项目管理
持续集成与敏捷开发
敏捷过程实践
敏捷测试-简单而可行
更多...   
成功案例
英特尔 SCRUM-敏捷开发实战
某著名汽车 敏捷开发过程与管理实践
北京 敏捷开发过程与项目管理
东方证券 基于看板的敏捷方法实践
亚信 工作量估算
更多...