版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、GRASP(General Responsibility Assignment Software Patterns)创建者(Creator)问题:谁创建了A?解决方案:如果以下条件之一为真时(越多越好),将创建类A实例的职责分配给B:l B“包含”或组成聚合了Al B记录Al B紧密地使用Al B具有A的初始化数据举例:比如在富客户端应用开发中,主程序创建一个主窗口对象,然后有主窗口对象来负责创建它内部的各种菜单、按钮等对象(而不是由主程序来创建这些菜单或按钮对象之后,再把它设置到主窗口中去)信息专家(Information Expert)问题:给对象分配职责的基本原则是什么?解决方案:把职责
2、分配给具有完成该职责所需信息的那个类。(描述一种直觉!)举例:public class Classes private int id;private Set students;/描述一种直觉public void addStudent(Student student)if(students = null)students = new HashSet();students.add(student);/将职责放在拥有这个职责所需信息的那个类中public boolean hasStudent(Student student)for (Iterator iterator = students.ite
3、rator(); iterator.hasNext();) Student s = (Student) iterator.next();if(s.equals(student)return true;return false;public class Student private int id;private String name;/判断两个学生对象是否相同的职责,交给Student来完成,因为它拥有这个/职责所需要的所有信息public boolean equals(Student student) if(name.equals(student.getName()return true;
4、return false;public class TreeNode private int id;private int level;private String nodeName;private TreeNode parent;private List<TreeNode> children;public void print()for(int i=0; i<level; i+)System.out.print("-");System.out.println(nodeName);for (Iterator<TreeNode> iterator
5、 = children.iterator(); iterator.hasNext();) TreeNode node = iterator.next();node.print();低耦合(Low Coupling)所谓耦合,即两个对象之间联系的紧密程度问题:如何减少因变化产生的影响?解决方案:分配职责以使耦合保持在较低的水平。低耦合是构建软件最重要的目标之一。要注意:我们讲低耦合,是降低与不稳定系统之间的耦合度,而不是那些稳定的系统,比如说我们在JAVA编程过程中,没有必要想专门的办法来降低与JDK核心类库之间的耦合度,因为JDK核心类库非常稳定,很少会发生变化。高内聚(High Cohesi
6、on)所谓内聚,即对象职责的相关性(或对象的操作之间联系的紧密程度)。高内聚,即保持对象职责的高度相关性。不良内聚和不良耦合往往都是齐头并进的!问题:怎样保持对象是有重点的、可理解的、可管理的,并且能够支持低耦合?解决方案:分配职责以保持较高的内聚性。内聚性较低的类,要做许多不相关的工作,或需要完成大量的工作。这样的类是不合理的。这样的类会有下列问题:l 难以理解l 难以复用l 难以维护l 脆弱,经常会受到变化的影响高内聚、低耦合是我们进行系统设计时,应该尽量要达到的目标。但是在某些情况下,这些原则也许不太合适。比如在分布式系统的开发中。分布式系统开发中的分布式对象之间的互相调用,可能会跨越网
7、络,跨网络调用会导致系统性能的下降,为了提高性能,所以必须寻找某种手段来降低跨网络调用的次数。控制器(Controller)问题:在UI层下首先接收和协调(“控制”)系统操作的对象是什么?解决方案:把职责分配给能代表下列选择之一的对象:l 代表整个“系统”、“根对象”(外观控制器)。 - 一般用Façade模式来实现l 代表发生系统操作的用例场景(用例控制器)。 - 如果使用Façade来实现一个外观控制器,会使得这个控制器非常臃肿,那么可以考虑采用用例控制器。举例:比如说,“导入组织机构的数据”用例,要求能够在界面上上传两个Excel文件,一个Excel是部门信息,一个E
8、xcel是人员信息。那么在实现这个用例的时候,UI层在接收到数据之后,应该将业务逻辑统一交给一个业务逻辑处理对象来完成。很显然,这个业务逻辑对象,需要调度Excel处理相关的对象、人员信息处理相关的对象、部门信息处理相关的对象等来完成这个导入数据的业务。此业务逻辑对象就是用例控制器。要注意:MVC中的C,并不是我们这里的控制器。因为MVC中的C处于UI层,而不是业务逻辑层。多态(Polymorphism)问题:如何处理基于类型的选择?如何创建可插拔的软件构件?解决方案:当相关选择或行为随类型(类)有所不同时,使用多态操作为变化的行为类型分配职责。不要测试对象的类型,也不要使用条件逻辑来执行基于
9、类型的不同选择。纯虚构(Pure Fabrication)问题:当你并不想违背高内聚和低耦合或其它目标,但是基于专家模式所提供的方案又不合适时,哪些对象应该承担这一职责?(很多情况下,只对领域对象分配职责会导致不良内聚或耦合,或者降低复用潜力)解决方案:对人为制造的类分配一组高内聚的职责,该类并不代表问题领域的概念虚构的事物,用以支持高内聚,低耦合和复用。所有GOF设计模式(或其它模式)都是纯虚构。间接性(Indirection)问题:为了避免两个或多个事物之间的直接耦合,应该如何分配职责?如何使对象解耦合,以支持低耦合并提供复用性潜力?解决方案:将职责分配给中介对象,避免它们之间的直接耦合。
10、中介实现了间接性。大量GOF模式,如适配器、外观等等都是间接性的体现。防止变异(Protected Variation)问题:如何设计对象、子系统和系统,使其内部的变化或不稳定性不会对其它元素产生不良影响?解决方案:识别预计变化或不稳定之处,分配职责用以在这些变化之外创建稳定接口。几乎所有的软件或架构设计技巧,都是防止变异的特例,比如封装、多态、接口、虚拟机、配置文件等等等等!OOD原则单一职责原则(SRP)就一个类而言,应该仅有一个引起它变化的原因。开放-封闭原则(OCP)软件实体(类、模块、函数等等)应该是可以扩展的,但是不可修改的。1、 对于扩展是开放的这意味着模块的行为是可以扩展的。当
11、应用的需求改变时,我们可以对模块进行扩展,使其具有满足那些改变的新行为。2、 对于更改是封闭的对模块的行为进行扩展时,不必改动模块的源代码或者二进制代码。OCP背后的主要机制是抽象与多态!Liskov替换原则(LSP)子类型必须能够替换掉它们的基类型。简单的例子:违反LSP原则的例子public void saysomething(Language lan)String tempStr = ""if(lan instanceof Chinese)tempStr = "中文"if(lan instanceof English)tempStr = "
12、;英文"System.out.println("现在你学习的语言是:"+tempStr);因为如果传递到saysomething方法中的Language是一个Japanese对象时,它将无法处理!要让它符合LSP也非常简单:public abstract class Language public abstract String toString();public class Chinese extends LanguageOverridepublic String toString() return "中文"public class English extends LanguageOverridepublic String toString() return "英语"public void saysomething(Language lan)System.out.prin
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 城市绿化合同管理办法
- 宗教艺术博物馆管理办法
- 一站式工程维护服务承诺书
- 车辆限号管理办法
- 美容院实习生转正合同
- 城市供电设施拆迁电力保障
- 生态养殖场养猪场租赁
- 城市绿化箱涵施工合同
- 产品售后服务承诺书协议书
- 建筑照明工程合同
- 教师带实习生总结8篇
- 《我国企业会计信息质量的现状、成因及治理对策(论文)7200字》
- 职工转移申请表
- (煤矿)矿灯自救器管理工理论考试题库200题(含答案)
- 基于核心素养导向的初中数学试题命制策略与实例课件
- 网络安全检查表模板
- ZXV10 T502(V1.0)会议电视终端
- 贵州省火力发电企业名录2017年125家
- 过敏性休克的急救及处理流程教材课件(28张)
- 二年级上册科学二单元《材料》教材解读
- 思想道德与法治课件:第四章 第一节 全体人民共同的价值追求则
评论
0/150
提交评论