`

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) 

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

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

分享到:
评论

相关推荐

    GRASP原则/模式

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

    OOD原则 GRASP GOF

    **GRASP原则:一般责任分配策略(General Responsibility Assignment Software Principles)** GRASP原则是指导如何合理分配对象职责的一组原则,有助于提高代码的可读性和可维护性。 1. **控制器(Controller)**...

    GRASP模式简介

    GRASP 模式简介 GRASP 模式是 General Responsibility Assignment Software Pattern(通用指责分配软件模式)的缩写。它是一种软件设计模式,旨在帮助开发者设计出更加灵活、可维护和可复用的软件系统。 GRASP ...

    对grasp的理解和应用

    总结来说,GRASP原则是软件设计中的重要指导思想,特别是高内聚和低耦合原则,它们有助于构建出易于维护、可扩展的软件系统。通过理解并应用这些原则,开发者可以更好地组织代码,提高团队协作效率,以及应对未来...

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

    除了GRASP原则,还有其他设计原则如: 1. “开-闭”原则(OCP):软件实体(如类、模块)应对扩展开放,对修改关闭。这意味着我们可以通过添加新代码来扩展功能,而不是修改现有代码。 2. 里氏代换原则(LSP):...

    GRASP72GREEN+备份.zip

    【标题解析】:“GRASP72GREEN+备份.zip”这个标题暗示了这是一个关于“GRASP72GREEN”项目的备份文件,被压缩成ZIP格式。"GRASP72GREEN"可能是项目、软件或系统的名称,而"+"通常用于表示版本升级或增强。"备份"则...

    软件需求分析课件:Chap 7-GRASP.ppt

    在软件需求分析中,GRASP原则帮助开发者在创建领域模型后,确定方法归属、定义对象间的消息交互,从而更好地满足需求。 在Elaboration Iteration 1中,GRASP原则被引入,它包括多个核心的设计模式,如Controller、...

    UML-GRASP模式简述

    GRASP 模式包括 9 个基本原则: 1. 创建者(Creator)模式:将创建一个类 A 的实例的职责指派给类 B 的实例。 2. 信息专家(Expert)模式:将职责分配给具有履行职责所需要的信息的类。 3. 低耦合(Low Coupling)...

    使用GRASP的对象设计示例

    GRASP模式提供了一些基本原则和策略,指导开发人员在设计对象时分配责任和确定对象之间的关系。 在GRASP模式中,对象设计的目标是将责任分配给正确的对象,以便将系统功能分解成小的、独立的对象。GRASP模式提供了...

    模式和原则

    设计模式和GRASP原则为软件开发提供了强大的工具箱,帮助开发者构建出高质量、易于维护的软件系统。通过学习和实践这些原则,可以显著提升软件项目的成功概率。无论是新手还是资深开发者,都应该重视对这些模式和...

    软件需求分析课件:Chap 9-Iteration 2--More GRASP.ppt

    总的来说,这个课件涵盖了软件开发中的迭代方法,特别是迭代二的关键点,包括需求分析、对象设计、设计模式的应用以及GRASP原则,这些都是软件需求分析中的核心知识点。通过实例分析NextGen POS和Monopoly游戏,帮助...

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

    结合GRASP原则和设计原则,我们可以构建出更灵活、可扩展的系统。设计模式如工厂模式、策略模式、观察者模式等都是这些原则的具体应用。《设计模式和原则》这本书深入浅出地介绍了这些概念,是IT从业者进阶学习的...

    软件开发设计原则软件开发设计原则

    11. **GRASP(General Responsibility Assignment Software Principles)原则** - 包括如控制器(Controller)、工厂(Factory)、多态(Polymorphism)等设计模式,用于指导类和对象的职责分配。 以上设计原则是...

    技术架构视图-设计原则与模式

    本文将深入探讨面向对象设计原则,尤其是开闭原则、依赖倒置原则、Liskov替换原则以及一些设计模式,如GRASP模式。 #### 开闭原则:灵活性与稳定性的平衡 开闭原则(Open/Closed Principle, OCP)主张软件实体(类、...

    GRASP更多具有职责的对象ppt课件.ppt

    总结来说,GRASP模式提供了一套指导原则,帮助我们在面向对象设计中合理地分配职责,以提高系统的可扩展性和可维护性。多态、纯虚构、间接性和防止变异这四个模式都是为了实现这一目标,让我们的代码更加灵活、模块...

    设计模式 设计模式 思想 模式 原则

    ### 设计模式与GRASP原则详解 #### 一、设计模式概述 设计模式是指在软件设计过程中,针对一些常见问题的解决方案。它并不是一个具体的代码片段或者类库,而是一种解决问题的思想方法。设计模式能够帮助开发者更好...

    系统架构的设计原则.docx

    1. **GRASP原则** - 通用职责分配软件模式: - **信息专家**:职责应赋予拥有执行职责所需信息的对象。 - **创建者**:负责创建对象的类通常是紧密相关的。 - **低耦合**:减少对象之间的依赖,增强系统的灵活性...

    讲述了面向对象设计的原则

    本文将深入探讨面向对象设计的核心原则及其应用,并结合GRASP(General Responsibility Assignment Software Patterns)模式进行详细分析。 ### 一、面向对象设计概述 面向对象设计(Object-Oriented Design, OOD...

    模式与原则[借鉴].pdf

    GRASP包含了9种模式,它们定义了对象设计和职责分配的基本原则,为如何将现实世界问题抽象为对象提供指导。 1. **信息专家(Information Expert)**:这是面向对象设计的基本原则,表示职责应分配给拥有完成该职责...

Global site tag (gtag.js) - Google Analytics