`
fjilyfe
  • 浏览: 39702 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

简述GRASP设计原则

阅读更多

                                                                         简述GRASP设计原则 

       GRASP(General Responsibility Assignment Software Pattern)是通用职责软件分配模式。GRASP的核心是自己干自己能干的事,自己只干自己的 事,也就是职责的分配和实现高内聚。用来解决面向对象设计的一些问题。GRASP提出了九大原则,下面笔者将对这九大设计原则做一一阐述。



高内聚、低耦合(High Cohesion、Low Coupling)

       在面向对象的程序设计时,小到一个类,大到一个功能模块,如果他们之间的相依性很高就会对整个软件的开发造成诸般障碍。例如:当你修改一个类或者某一个模 块的时候,相应的你要改动其他的与之相依赖的类和模块,使得程序很难维护;代码会变得很难理解,一个很单一的操作,就会涉及到很多程序之间相互调用;程序 更是难以复用,当你想复用一个类的时候,对应的与之想依赖的类或方法也会被陆陆续续的添加进来。

        这就是我们为什么要遵循这一原则的原因,而高内聚和低耦合往往是伴随在一起出现的。低耦合其实就是两个类或模块之间联系的紧密程度,高内聚就是类中方法和 方法之间的职责相关性。要想避免低内聚、高耦合,解决办法就是既要降低因为一个类的变化而对另一个类产生的影响,又要保持类或模块是有重点的、可理解的、 可管理的并且支持低耦合的,也就是更加精确的给一个类或者模块分配职责。

        高内聚和低耦合是软件开发中最重要的原则,grasp的其他模式也是以高内聚、低耦合原则为中心的。


信息专家(Information Expert)

        如何实现高内聚,也就是如何给类分配职责?我们要遵循的原则就是把职责分配给具有完成该职责信息的那个类。


创建者(Creator)

如何分配创建对象的职责呢?原则就是当下列条件满足时(越多越好),由B创建A:
1.B频繁的使用A
2.B包含或聚合了A

         举个简单的例子,如果类A实现了B接口,类C、D是类A的一个属性,那么C、D应该由A来创建,A应该由B来创建。如果C、D由B来创建,那么当C或者D改变的时候,B 和A也要跟着改变,大大增强了B和C、D的之间的耦合度,违背了低内聚的原则。通俗点说就是如果B使用的了A,那么就应该由B来创建A,而不是由其他的类来创建。


控制器(Controller)

        在UI层外,应该由哪个类来处理系统操作呢?原则就是把系统事件的处理职责分配给控制器类,这个控制器类就相当于MVC中的C。这个控制器类通常是系统事件放生 的用例的控制类。


多态(Polymorphism)

        根据类型的不同而发生变化的行为的定义职责,应该分配给谁?

举个简单的例子,坐车去广州,坐车算是一个行为,但是这个行为是可以变化的,比如坐飞机、坐汽车或者坐火车,那么坐车这个行为的定义应该分配给谁呢?

        原则是通过多态操作把基于类型的可变行为的定义职责分配给发生该行为的类。放到JAVA当中来实现就是定义一个坐车的接口,然后具体的坐飞机、坐汽车或者坐火 车的行为分别定义一个类来实现该功能,然后让这三个具体的类去实现坐车接口。


纯虚构模式(Pure Fabrication)

        非问题领域的职责应该分配给谁?

        我们在设计类的时候,通常都尽量的保持和现实世界当中的对象一致,那么我们从现实世界的对象抽象出来的类就叫做问题领域里的类,那么当我们保存这个对象的 时候要操作数据库,操作数据库就是一个非现实世界存在的业务对象,他就是非问题领域的职责。

        这种职责分配的原则就是将非问题领域的职责分配给人工生成的类。比如问题领域的类通常是放到PO里面的,他不应该包括CRUD等操作。那么CRUD这些操作应该放 到一个人工生成的也就是我们在业务逻辑以外加的一个类。


间接性(Indirection)

        为了避免两个或多个事物之间直接耦合,应该如何分配职责? 

        设计原则是将职责分配给中介对象。例如类A和类B是多对多的关联关系,当A改变的时候,B需要做相应的改变,当B改变的时候,A需要做相应的改变,这是违反低耦 合原则的,解决方法就是在A和B之间加入一个C类,类C的属性只有A和B,用C来记录A和B之间的关系,当A想使用B或者B使用A的时候,他们都通过C来调用对方。


防止变异(Protected Variation) 

        如何设计对象、系统和子系统,使其内部的变化或者不稳定因素不会对其他元素产生不良影响? 

        预计识别不稳定的因素,在其外部创建稳定的接口。例如:坐汽车去广州当中的坐汽车就是一个不稳定的因素,以后也许会坐飞机或者火车,那么我们就要把坐汽车 抽象出一个坐车的接口,当有一天想坐火车的时候直接加一个实现的类就可以了。





 

1
0
分享到:
评论
3 楼 housheng33 2013-02-22  
通用职责软件分配模式。GRASP的核心是自己干自己能干的事,自己只干自己的 事,也就是职责的分配和实现高内聚
2 楼 yyuzhang2008 2008-08-28  
很好,很强大
1 楼 fly_java 2008-08-26  
o(∩_∩)o...

相关推荐

    GRASP原则/模式

    GRASP模式,OO原则和设计模式的基础,原创不易,请珍惜下载

    UML-GRASP模式简述

    GRASP模式,这个模式出自《UML和模式应用》,GRASP是General Responsibility Assignment Software Pattern(通用责任分配软件模式)的缩写

    设计模式和原则(很实用)

    讲解:GRASP (职责分配原则),GRASP是学习使用设计模式的基础;讲解:设计原则,设计原则是设计模式的灵魂。

    使用GRASP的对象设计示例

    使用GRASP的对象设计示例使用GRASP的对象设计示例使用GRASP的对象设计示例

    OOD原则 GRASP GOF

    NULL 博文链接:https://wuaner.iteye.com/blog/587112

    GRASP\GRASP_source.rar

    GRASP\GRASP_source.rar

    对grasp的理解和应用

    武汉大学软件工程uml——finalreport在软件工程专业中,思维对于我们来说是非常重要的一个部分,而学习软工框架,是十分有利于培养我们的...在实战之中,我对理论课学习的知识有了更深入的了解,其中包括了GRASP原则

    论文研究-H-GRASP:一种基于GRASP改进的混合SAT解法器.pdf

    为了改善GRASP的局限性,提出了一种能解决含有伪布尔(PB)和合取范式(CNF)混合约束问题的新的混合算法(H-GRASP)。该新算法采用了切削平面技术来提取PB约束条件之间的推论,并把它结合到普通的蕴涵图中,分析...

    GRASP模式简介

    介绍部分关于GRASP模式的知识 GRASP是General Responsibility Assignment Software Pattern(通用指责分配软件模式)的缩写。

    GRASP72GREEN+备份.zip

    GRASP72GREEN+备份.zip

    第17章grasp基于职责设计对象.pptx

    第17章grasp基于职责设计对象.pptx

    java\软件设计中的原则(GRASP)

    真的很好。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

    面向对象软件架构设计

    用GRASP模式指导设计 62 领域模型 96 面向对象设计的基本原则 132 第三单元:用UML辅助系统分析与设计 177 UML简介及常见疑难问题辨析 178 借鉴RUP的UML建模与分析 213 第四单元:设计模式与软件设计思想 267 设计...

    GRASP(空间回归分析与预测工具学习)

    GRASP(空间回归分析与预测工具学习)

    管家婆grasp7.1完美版本

    一般的管家婆软件在数据库记录超过2万条就开始报错,需要修复,我这个是一点问题都没有的。稍候我将把之前错误修复的程序放上来,供大家参考。资源名称:管家婆7.1错误修复程序

    grasp help

    grasp 帮助文件,用于反射面天线仿真的说明,可以进行卫星天线仿真等设计,多波束天线仿真,包括多种馈源实例,采用po等方式仿真和优化,大大提高了仿真速度。

    面向对象软件架构设计.ppt

    用GRASP模式指导设计 62 领域模型 96 面向对象设计的基本原则 132 第三单元:用UML辅助系统分析与设计 177 UML简介及常见疑难问题辨析 178 借鉴RUP的UML建模与分析 213 第四单元:设计...

    GRASP实验室飞控

    GRASP实验室飞控技术:We study the problem of designing dynamically feasible trajectories and controllers that drive a quadrotor to a desired state in state space. We focus on the development of a ...

    GRASP10[1].3.0培训教程(公开).pdf

    GRSP培训软件,十分珍贵,有例子,有基础介绍,非常实用,是天线仿真的必备软件之一

Global site tag (gtag.js) - Google Analytics