UML的全称是统一建模语言:Unified Modeling Language。

是用来为面向对象开发系统的产品进行说明可视化和编制文档的方法。

它是一种标准的图形化建模语言,是面向对象分析与设计的一种标准表示。

它的本意是可以使IT人员进行程序设计的建模。它不是程序设计语言,而是建模语言。

UML架构

UML由图和元模型组成。

图是UML的语法,元模型是语义,是图的意思。UML语义定义在四个抽象级:

1元元模型:组成UML最主要的元素“事物”,代表要定义的全部事物。

2元模型:是UML的基本元素。包含了面向对象和面向组件的概念。这一层的概念都是“远远模型”中的“事物”概念的实例。

3模型层:组成了UML的模型,这一层中的概念都是元模型层中概念的实例。这一层中的模型通常叫做类模型或概念模型

4用户模型:这层中的全部元素都是UML模型的样例。这层中的概念都是模型中的一个实例(通过分类),也是元模型的一个实例(通过版类化)。这一层的模型通常叫做对象模型或实例模型。

UML的模型、视图、图和系统架构建模

UML用来描写叙述模型。模型能够表示系统的结构和行为特征、以及行为和动态特征。从不同角度为系统架构建模,能够形成不同的模型图。包含

1、用例视图:强调从用户角度看到的或须要的系统功能,也被称作用户模型视图或想定视图。

包含:用例图。

2、逻辑视图:展现系统静态或结构组成特征,也称作结构模型视图或静态视图。

包含:类图、对象图。

3、并发视图:体现系统动态或行为特征,也叫做行为模型视图、过程视图、协作视图、动态视图。

包含:序列图、协作图、状态图、活动图。

4、组件视图:体现了系统实现的结构和行为特征。也叫做实现模型视图、开发视图。

包含:组件图。

5、展开视图:体现了实现环境的结构和行为特征,也叫做环境模型视图、物理视图。

包含:展开图。

模型图包含

1、事物:模型中最基本元素,具有代表性成分的抽象。

2、关系:它把事物紧密联系在一起。

3、图:事物和关系的可视化表示。

事物

UML包括四种事物:构建事物、行为事物、分组事物、凝视事物

构建事物

它是模型的静态部分。描写叙述概念或物理元素。包含:类、接口、协作(描写叙述一组事物的相互作用的集合)、用例(表示一个系统或系统一部分行为,是一组动作序列的集合)、构件(系统中物理存在。能够替换)、节点(执行时存在的物理元素)。
參与者、信号应用、文档库、页表等都是基本事物的变体。

行为事物

UML模型的动态部分,描写叙述跨越空间和时间的行为,包含
交互:实现某功能的一组构件事物的消息的集合,涉及消息、动作序列、链接等。

状态机:描写叙述事物或交互在生命周期内响应事件所经历的状态序列。

分组事物

UML模型视图的组织部分。描写叙述事物的组织结构。

凝视事物

UML模型的解释部分,用来对模型中元素进行解释说明。

关系

关系包含
1、依赖:两个事物之间的语义关系。当中一个事物(独立事物)发生变化。会影响到还有一个事物(依赖事物)语义。

2、关联:是一种结构关系。指明一个事物的对象与还有一个事物对象的关系。
3、泛化:一般和特殊的关系。即继承关系。
4、实现:类元之间的语义关系,当中一个类元指定了由还有一个类元保证运行的契约。


UML中的图

用例图:
用例图是从用户角度描写叙述系统功能。是用户所能观察到的系统功能模型图。用例图的主要目的是帮助开发团队理解系统的功能需求。

类图:
类图表示不同的实体怎样彼此相关,描写叙述了系统的静态结构。类图以类为中心来组织。

对象图:
对象图是类图的实例。标识和类图差点儿同样,差别在于对象图显示类的多个对象的实例,而不是实际的类。

顺序图:
顺序图显示了了对象之间动态合作关系,强调对象之间发送消息的顺序,同一时候显示对象之间的交互。


协作图:
协作图是描写叙述对象间的协作关系,跟顺序图相似。显示对象间动态合作关系,比如信息交换。以及对象之间的关系。


状态图:
状态图表示一个类实例对象可能经历全部状态转换信息。


活动图:
活动图表示在处理某个活动时。两个或很多其它对象之间的过程控制流,描写叙述了一组顺序的或并发的活动。


构件图:
构件图提供了系统的物理视图。用来显示系统中的各种构件之间的依赖关系。

部署图:
部署图描写叙述该软件怎样部署到硬件环境中。

以下是8中图的关系(没有部署图)


UML简单介绍的更多相关文章

  1. UML简单介绍—类图详解

    类图详解 阅读本文前请先阅读:UML简单介绍—类图这么看就懂了 1.泛化关系 一个动物类: /** * 动物类 */ public class Animal { public String name; ...

  2. UML简单介绍-如何看懂UML(一)

      在计算复杂的数学题时,我们必然会打草稿计算 在绘画课中,我们可以素描出来看到的事物 那么在程序设计中呢? 如何描绘传达你脑海中的关于这个程序 ,设计的蓝图草稿?   OOP的程序设计中,最多的自然 ...

  3. UML简单介绍—类图这么看就懂了

    如何看懂类图 1.类图简介 描述类的内部结构和类与类之间的关系,是一种静态结构图. 在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关 ...

  4. UML 简单介绍

    Unified modeling Language - 统一建模语言

  5. UML动态模型图简单介绍

    UML动态模型图描述了系统动态行为的各个方面,包括用例图.序列图.协作图.活动图和状态图.下面就每种图做一个简单介绍: 用例图 用例图描述系统外部的执行者与系统提供的用例之间的某种联系.所谓用例是指对 ...

  6. Spring Framework简单介绍

    Spring Framework        学习java编程不知不觉已经三年时间了,開始的时候,总是喜欢看着视频,然后按部就班的敲打着键盘,每当系统正常执行后.心里乐开了花.最開始的时候,所有的代 ...

  7. [原创]关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  8. 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍

    一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...

  9. 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍

    一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...

随机推荐

  1. 前端面试题整理(css)

    1.介绍所知道的CSS hack技巧(如:_, *, +, \9, !important 之类). CSS hack的原理: 由于不同的浏览器和浏览器各版本对CSS的支持及解析结果不一样,以及CSS优 ...

  2. HTML文档类型DTD与浏览器怪异模式

    虽然在兼容IE6时候经常会注意到两个模式的区别,但是系统的理解起来,还没有认真总结过.看了一些网上的资料.结合自己的理解汇总了一下,放在这里备忘并分享给大家. 浏览器从服务端获取网页后会根据文档的DO ...

  3. Oracle、DB2、MySql、SQLServer JDBC驱动

    四种数据库JDBC驱动,还列出了连接的Class驱动名和Url Pattern,DB2包括Type 2.Type 3和Type 4三种模式.注意驱动包名称的大小写. Oralce连接驱动包名和URL ...

  4. Android Studio经常使用操作技巧(不断更新)

    这段时间一直在用Android Studio做一些Demo的开发.一開始从Eclipse中转向这个开发工具,各种不适应,希望此博文能够一直更新.还有网友能够分享出自己方便更好更快开发的一些技巧. 首先 ...

  5. Web用户控件

    用户控件是个什么东西?自定义的反复重用的控件集合 注意:创建好用户控件后,必须添加到其他web页中才能显示出来,不能直接作为一个网页来显示,因此也就不能设置用户控件为“起始页”. 用户控件与ASP.N ...

  6. GDI+ Tutorial for Beginners

    原文 GDI+ Tutorial for Beginners GDI+ is next evolution of GDI. Using GDI objects in earlier versions ...

  7. Flex上传文件

    前几天写了一篇jsp页面利用ajaxFileUpload上传文件.如今把flex上传页面也分享出来: 前台页面 <?xml version="1.0" encoding=&q ...

  8. 采用管道处理HTTP请求

    采用管道处理HTTP请求 之所以称ASP.NET Core是一个Web开发平台,源于它具有一个极具扩展性的请求处理管道,我们可以通过这个管道的定制来满足各种场景下的HTTP处理需求.ASP. NET ...

  9. uva 140

    思路:暴力+剪枝 uva140 wa了好多次……数组开小了……!!! #include <iostream> #include <cstdio> #include <cm ...

  10. HTML5 实现拖拽

    如图 可以从第一个方框拖拽花色到第二个方框中. 也可以再拖动回来. 具体代码实现 index.html <!DOCTYPE HTML> <html> <head> ...