类结构的表示方式:类图(Class Diagram)

以下示例:sql

类(Class)封装了数据和行为,是面向对象的重要组成部分,它是具备相同属性、操做、关系的对象集合的总称。数据库

 

类通常由三部分组成:

类名(Class):每一个类都必须有一个名字,类名是一个字符串。 工具

属性(Attributes):属性是指类的性质,即类的成员变量。类能够有任意多个属性,也能够没有属性。spa

  UML中:可见性 名称:类型 [= 默认值]设计

操做(Operations):操做是类的任意一个实例对象均可以使用的行为,操做是类的成员方法。orm

  UML中:可见性 名称(参数名):返回值对象

 

接下来咱们看一下类的关系:

要注意uml中的关系是面向对象关系。若是不以面向对象的思惟去考虑会感受到有不少关系认为是同样的。继承

 

关联关系(Association)

一般关联关系用来实现链接有关联的对象所对应的类,即将一个类的对象做为另外一个类的属性。接口

还有就是关联关系能够是单向的也能够是双向的。双向的符号是没有方向标的,只是一条直线。ip

例:

单向:

双向:

本身:

多重性关联关系:

例:

 

在这里要注意,看完此图中1…1之后不要认为一个Form是对应一个Button的。

不是的,应该是一个Button是对应一个Form的。1..1是表示另外一个类的一个对象只与一个该类对象有关系。记住上面的表格。是另外一个类与该类是什么关系。

 

聚合关系(Aggregation)

表示总体与部分的关系。考虑到一个总体类的组成结构。找出成员类。即成员对象是总体对象的一部分,可是成员对象能够队里总体对象独立存在。因此也有人说此关系是一种弱关系,那么强关系是什么后面咱们会降到组成关系。

聚合关系有一个特色,那就是可替换

 

直观的来看此图Car中必须得有一个Engine,这样才能够认为是一个完总体。

可是这个Engine是可替换的。是以传参的形式给Car赋一个Engine。

再次强调一下聚合是可替换的。Car中必须有一个Engine,可是此Engine能够是一个抽象的具体的Engine是在当你使用Car时能够具体去找一个合适的Engine装到Car上就行,若是没有Engin那么这个Car是跑不了。

 

组合关系(Composition)

表示总体与部分的关系。可是与聚合不一样此关系是总体与部分是同生共死关系。即若是总体对象销毁了部分也会被销毁。

 

上图Head是总体Mouth是部分,若是Head没了Mouth也跟着销毁了。若是Mouth没了Head也将是面目全非。在代码中Head中Mouth是直接new出来的。

就是说当你去new Head时Mouth也被new出来。记住一同建立一同销毁关系。也叫强关系。那么有人会问关联,聚合,组合我怎么认为是同样呢。

能够说他们是同样的均可以说是关联关系,是的,可是关联关系的强弱来区分了一下关联关系强度来看组合>聚合>关联

 

依赖关系(Dependency)

是一个使用关系。特定事物的改变有可能会影响到使用该事物的其余事物。简单说在一个类中经过另一个类来调用其方法的表示。

从图中能够看出Driver中使用了Car的move方法。那么就说明Driver是依赖于Car才能作Driver的职责。那么又有人会问聚合与依赖有区别吗,固然很明显Driver是一个总体,Car也是总体。不是总体与部分关系。

 

泛化关系(Generalization)

继承(extends)关系,父类与子类关系。这个好理解直接上图。

从图中能够看出Student也是Person,Teacher也是Person。他们有共同的特征name,age。可是也有独自的特征一个是study一个是teach的特征。

子类那么就是Student,Teacher父类是Person。继承了父类那么子类能够直接适用父类的方法或属性(家产)。

 

实现关系(Realization):

类实现(implements)了接口.当多个类有相似的行为方式的时候咱们一般会适用接口。

Ship,Car都有move的特征他们都属于交通工具(Vehicle)只是他们move的方式不同。那么咱们就能够适用接口实现的方式去设计。代码中是public class Car implements Vehicle

 

好咱们来看一下一个完整的类图例子:

 

回顾一下以前关系。去分析一下此UML的类图。

用户经过注册界面(RegisterForm)输入我的信息,
用户点击“注册”按钮后将输入的信息经过一个封装用户输入数据的对象(UserDTO)传递给操做数据库的数据访问类(DAO),
为了提升系统的扩展性,针对不一样的数据库可能须要提供不一样的数据访问类,所以提供了数据访问类接口,
如IUserDAO,每个具体数据访问类都是某一个数据访问类接口的实现类,
如OracleUserDAO就是一个专门用于访问Oracle数据库的数据访问类。

UserDTO只是把userAcount,userPassword封装了一下使用了Getter,Setter。

那么确定是RegisterForm的成员,注册窗体不能没有用户名与密码信息因此是组合关系。RegisterForm没有了用户信息(UserDTO)那么就没有意义了。

而后IUserDAO与RegisterForm是聚合关系由于是能够替换的。好比说你可使用Oracle的之后扩展成Mysql的那么能够方便替换。

考虑到从此会扩展UserDAO因此适用了接口。

IUserDAO为何与UserDTO是依赖关系,由于IUserDAO要把用户信息保存到数据库中那么必须须要用户信息。若是没有了用户信息此工做没法完成因此是依赖关系。

相关文章
相关标签/搜索