UML
UML(unified model language)统一建模语言。是一种标准的图形化建模语言。主要用于软件的分析和设计,用定义完善的符号来图形化展示软件系统。UML不涉及编程问题,即与语言平台无关,就使得开发人员可以专注于建立软件系统的模型和结构。
结构图中比较常用的是类图和对象图。行为图中比较常用的有用例图、状态机图、顺序图。
类图
类图由三部分组成:类名,属性,方法
各个类之间的关系有以下:
Is-a关系:继承关系。是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。在类图中使用带三角箭头的实线表示,箭头从子类指向父类。
接口与实现类之间的关系:跟继承的区别在于线条是虚线
依赖关系:对象之间最弱的一种关联方式,是临时性的关联。在代码中一般指局部变量,函数参数,返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个雷的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。
关联:对象之间一种引用关系,比如客户类与订单类之间的关系。这种关系通常使用类的属性表达。关联又分为一般关联、聚合关联与组合关联。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。
聚合:表示has-a的关系,是一种不稳定的包含关系。较强于一般关联,有整体与局部的关系,并且没有了整体,局部也可单独存在。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。在类图使用空心的菱形表示,菱形从局部指向整体。
组合:表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。
要注意区分聚合和组合,好聚好散,因此聚合的关系没有组合那么强烈。而组合关系的part是不可以单独存在的。
聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。
多重关系:通常在关联、聚合、组合中使用。就是代表有多少个关联对象存在。使用数字..星号(数字)表示。如下图,一个割接通知可以关联0个到N个故障单。