简述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模式,OO原则和设计模式的基础,原创不易,请珍惜下载
"UML-GRASP模式简述" GRASP 模式是 General Responsibility Assignment Software Pattern(通用责任分配软件模式)的缩写,这个模式出自《UML 和模式应用》。在建立概念模型时,GRASP 模式可以指导我们如何分配类的...
**GRASP原则:一般责任分配策略(General Responsibility Assignment Software Principles)** GRASP原则是指导如何合理分配对象职责的一组原则,有助于提高代码的可读性和可维护性。 1. **控制器(Controller)**...
GRASP模式提供了一些基本原则和策略,指导开发人员在设计对象时分配责任和确定对象之间的关系。 在GRASP模式中,对象设计的目标是将责任分配给正确的对象,以便将系统功能分解成小的、独立的对象。GRASP模式提供了...
除了GRASP原则,还有其他设计原则如: 1. “开-闭”原则(OCP):软件实体(如类、模块)应对扩展开放,对修改关闭。这意味着我们可以通过添加新代码来扩展功能,而不是修改现有代码。 2. 里氏代换原则(LSP):...
结合GRASP原则和设计原则,我们可以构建出更灵活、可扩展的系统。设计模式如工厂模式、策略模式、观察者模式等都是这些原则的具体应用。《设计模式和原则》这本书深入浅出地介绍了这些概念,是IT从业者进阶学习的...
GRASP,全称为“贪婪搜索法的粗糙集理论应用”(Greedily Refined Search Algorithm using a Perturbation Heuristic),是一种在计算机科学和人工智能领域中常见的优化算法。它主要用于解决组合优化问题,如旅行商...
GRASP10是一款专业的天线仿真软件,广泛应用于天线设计与分析领域。其全称为Geometrical Theory of Diffraction and Physical Optics Simulation Program,意为几何绕射理论和物理光学仿真程序。GRASP软件基于高频...
综上所述,"GRASP72GREEN+备份.zip"这个压缩包很可能是一个包含多种图标设计资源的图库,适用于UI设计师或开发者在图标设计、应用开发等方面使用。了解上述知识点,将有助于更好地利用这些资源。
本文将深入探讨面向对象设计原则,尤其是开闭原则、依赖倒置原则、Liskov替换原则以及一些设计模式,如GRASP模式。 #### 开闭原则:灵活性与稳定性的平衡 开闭原则(Open/Closed Principle, OCP)主张软件实体(类、...
11. **GRASP(General Responsibility Assignment Software Principles)原则** - 包括如控制器(Controller)、工厂(Factory)、多态(Polymorphism)等设计模式,用于指导类和对象的职责分配。 以上设计原则是...
总结来说,GRASP原则是软件设计中的重要指导思想,特别是高内聚和低耦合原则,它们有助于构建出易于维护、可扩展的软件系统。通过理解并应用这些原则,开发者可以更好地组织代码,提高团队协作效率,以及应对未来...
在Elaboration Iteration 1中,GRASP原则被引入,它包括多个核心的设计模式,如Controller、Indirection、Low Coupling、High Cohesion、Protected Variation等。这些模式提供了如何设计具有明确责任的对象的指导...
【管家婆GRASP 7.1 完美版本】是一款针对中小型企业设计的全面企业管理软件,旨在帮助企业高效管理财务、进销存、生产等业务环节。这款软件以其稳定性、易用性和功能全面性赢得了广大用户的青睐。在描述中提到的问题...
GRASP 模式主要包括九大原则:专家模式、创建者模式、高聚合度或高内聚模式、低耦合度或低耦合模式、控制者模式、多态模式、纯虚构模式、中介者模式和不要和陌生人讲话模式。 1. 专家模式(Expert) 专家模式的...
- 课程不仅涵盖GOF设计模式,还会涉及面向对象设计原则、GRASP原则以及其他常用设计模式。 - **实战与理论结合**: - 课程采取案例驱动的方式,通过实战案例帮助学员深入理解设计模式的实际应用。 #### 五、总结 ...
为了改善GRASP的局限性,提出了一种能解决含有伪布尔(PB)和合取范式(CNF)混合约束问题的新的混合算法(H-GRASP)。该新算法采用了切削平面技术来提取PB约束条件之间的推论,并把它结合到普通的蕴涵图中,分析...
### GRASP:空间回归分析与预测工具学习 #### 引言 GRASP,全称Generalized Regression Analysis and Spatial Prediction(广义回归分析与空间预测),是一种先进的地理信息系统(GIS)工具,专门用于评估和预测...