依赖,聚合,组合
依赖,聚合,组合
2011-01-24 10:57
231人阅读
评论(0)
收藏
举报
class
c
设计模式
敏捷开发
uml
string
在java面向对象中,类与类之间的关系有依赖,聚合,组合等几种。 1,依赖 依赖表现为如果A类依赖于B类,则B体现为A的局部变量,方法参数或静态方法的调用。 例子如下: class B{ Static void f1(){}; voidf2(){}; } public class A{ public static void main(String[] args){ B.f1();//A类中调用了B类的静态方法 } } 聚合和组合都属于关联,很难区分,但是只要记住一点,区分它们就容易多了: 处于聚合关系的两个类生命周期不同步,则是聚合关系;处于组合关系的两个类的生命周期同步; eg: 聚合关系,当A创建的时候,B不一定创建;当A消亡时,B不一定消亡。 class A{ privateB; } class B{ .... } 组合关系,当创建一个A对象时,也会创建一个B对象;当A对象消亡时,作为A的属性的B对象也会消亡。 class A{ private b=new B(); .... } class B{ } UML的类图关系分为:关联、聚合/组合、依赖、泛化(继承)。而其中关联又分为双向关联、单向关联、自身关联;下面就让我们一起来看看这些关系究竟是什么,以及它们的区别在哪里。 1、关联 双向关联: C1-C2:指双方都知道对方的存在,都可以调用对方的公共属性和方法。 在GOF的设计模式书上是这样描述的:虽然在分析阶段这种关系是适用的,但我们觉得它对于描述设计模式内的类关系来说显得太抽象了,因为在设计阶段关联关系必须被映射为对象引用或指针。对象引用本身就是有向的,更适合表达我们所讨论的那种关系。所以这种关系在设计的时候比较少用到,关联一般都是有向的。 使用ROSE 生成的代码是这样的:
classC1
{ public: C2*theC2; }; classC2 { public: C1*theC1; }; 双向关联在代码的表现为双方都拥有对方的一个指针,当然也可以是引用或者是值。
classC3
{ public: C4*theC4; }; classC4 { }; 单向关联的代码就表现为C3有C4的指针,而C4对C3一无所知。
classC14
{ public: C14*theC14; }; 就是在自己的内部有着一个自身的引用。
classC9
{ public: C10theC10; }; classC10 { };
classC7
{ public: C8theC8; }; classC8 { }; 可以看到,代码和聚合是一样的。具体如何区别,可能就只能用语义来区分了。
//
C5.h
#include"C6.h" classC5 { }; C6.h #include"C5.h" classC6 { }; 虽然ROSE不生成属性,但在形式上一般是A中的某个方法把B的对象作为参数使用(假设A依赖于B)。如下:
#include"B.h"
classA { voidFunc(B&b); } 那依赖和聚合/组合、关联等有什么不同呢? 组合是一种整体-部分的关系,在问题域中这种关系很明显,直接分析就可以得出的。例如轮胎是车的一部分,树叶是树的一部分,手脚是身体的一部分这种的关系,非常明显的整体-部分关系。
#include"C11.h"
classC12: publicC11 { };
template<
int>
classC13 { }; 这里再说一下重复度,其实看完了上面的描述之后,我们应该清楚了各个关系间的关系以及具体对应到代码是怎么样的,所谓的重复度,也只不过是上面的扩展,例如A和B有着“1对多”的重复度,那在A中就有一个列表,保存着B对象的N个引用,就是这样而已。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |