0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

走马观花的将UML大致梳理了一下,并结合EA的例图

GReq_mcu168 来源:玩转单片机 2020-07-01 17:06 次阅读

[导读] 作为程序猿都最好掌握的一门语言,那就是UML(Unified Modeling Language),统一建模语言(UML)是软件工程领域中一种通用的开发建模语言,旨在提供一种可视化系统设计的标准方法。是开发人员、系统设计人员交流的有效工具。今天来分享一下UML的一些体会,如有错误请帮忙指正。

注:UML工具有很多,本文描述的基于Enterprise Architect。

UML时间进化线:

说到UML不得不提的三位大神,Grady Booch、Jacobson、James Rumbaugh,三位是UML的创始人,均为软件工程界的权威,除了著有多部软件工程方面的著作之外,在对象技术发展上也有诸多杰出贡献,其中包括Booch方法、对象建模技术(OMT)和Objectory(OOSE)过程。三人被合称为“UML三友”。

面向对象编程方法以及描述符号进化历史:

然后逐步发展到UML2.5标准。

UML目前的官方组织是https://www.uml.org/

宏观看UML

UML用图去描述一个软件系统,从需求、设计、到部署的方方面面都以及覆盖。那么从总体上先来看看UML有哪些图呢?

从描述系统建模目的,UML图可以分成下面4大类:

从建模的动态视角/静态视角,可以这样去分类:

微观看UML

UML由基本的组成可以从三大块去了解:事物/关系/图

事物(Things)

构件事物:UML模型的静态部分,描述概念或物理元素

类:具有相同属性相同操作 相同关系相同语义的对象的描述

接口:描述元素的外部可见行为,即服务集合的定义说明

协作 描述了事物间的相互作用的集合

用例:代表一个系统或系统的一部分行为,是一组动作序列的集合

构件:系统中物理存在,可替换的部件

节点:运行时存在的物理元素

另外,参与者、信号应用、文档库、页表等都是上述基本事物的变体

行为事物:UML模型图的动态部分,描述跨越空间和时间的行为

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

交互:实现某功能的一组构件事物之间的消息的集合,涉及消息、动作序列、链接

分组事物:UML模型图的组织部分,描述事物的组织结构

注释事物:UML模型的解释部分,用来对模型中的元素进行说明,解释

关系(Relationship)

下面是UML的基础4大关系:

实现(realization)是类元之间的语义关系,其中的一个类元指定了由另一个类元保证执行的契约

泛化(generalization)是一种特殊/一般的关系。也可以看作是常说的继承关系

关联(association)是一种结构关系,它指明一个事物的对象与另一个事物的对象间的联系

依赖(dependency)是两个事物之间的语义关系,其中一个事物(独立事物)发生变化,会影响到另一个事物(依赖事物)的语义

更为详细的描述,看看下面这些表吧:

图(Diagram)

用例图/Use Case Diagram:用于描述系统的参与者与用例间的关系

类图/Class Diagram:•类图以反映类的结构(属性、操作)以及类之间的关系为主要目的,描述了软件系统的逻辑结构,是一种静态建模方法

对象图/Object Diagram: 描述系统类在某个时刻的具体实例化情况,类似系统某时刻对象角度的快照

序列图/Sequence Diagram:描述对象间动态行为在一段时间的行为序列

时序图/Timing Diagram:描述对象在时间维度的动态行为

通讯图/Communication Diagram:类似序列图,相对序列图强调时间维度,通讯着重描述协作的逻辑关系

相互作用概视图/Interaction Overview Diagram:系统高层级的交互描述,可以引用其他序列图、时序图、通讯图、以及交互概视图

复合结构图/Composite Structure Diagram:复合结构图反映了类,接口或组件(及其组件)的内部协作属性来描述一个功能

信息流图/Info Flow Diagram:描述信息在对象间、构件、包、参与者之间的流向

状态机图/State Machine Diagram:用于描述元素在不同状态间如何迁移的逻辑联系

活动图/Activity Diagram:常用于描述系统级行为的实现建模。需要考虑多种因素:逻辑条件、并发、中断、数据访问等等

封装图/包图/Package Diagram:包图描绘了将模型元素组织到包中以及它们之间的依赖关系(包括包导入和包扩展等)。它们还提供相应命名空间的可视化。

构件图/Component Diagram:用于高层级描述系统的组成构件,以及构件间的依赖关系

部署图/Deployment Diagram:描述系统的部署方式(如何部署、部署在什么环境、硬件环境、软件环境等等)

.....

用例图

参与者/Actor:图中的小人,表示系统的用户,如人/机器/内部的其他子系统/硬件等

用例/Use Case:图中的椭圆框及描述,描述参与者与系统交互所实现的工作内容经常会配合附加文本进行详细描述。

边界/Boundary:方框,描述框里的都是属于建模对象里的东东,建模的时候可以方便识别与其他系统交互的接口

用例图在UML语言中处于至关重要的位置,所谓4+1架构设计,用例图用于描述系统需求,处于核心位置。属于Use-case drivering 大法的心脏。

类图/ Class Diagram

这个类图描述一个图像管理系统。

对象图/Object Diagram

描述一个图书管理系统某时刻对象的快照。

序列图/Sequence Diagram

此图说明了在交互中满足视图历史用例所需的对象。对象之间的消息流为用户提供了事务历史信息。描述图书管理系统如何查阅历史的操作系列,反应了客户端与各对象间消息传递关系。

时序图/Timing Diagram

这个类似于芯片的时序图概念。下图描述用户在有卡/无卡对系统访问的时间线场景图:

通讯图/Communication Diagram

这是一个嵌入式系统的UML建模,该图描述一个压力控制系统两个主要用例的实现:

压力控制循环,上面的数字以及箭头表示消息传递流向

通过HMI设置压力

交互概视图/Interaction Overview

描述了一个图书管理系统如何从订单发起后的所有交互概要图,每个子图上面的ref表示引用了一个更详细的图,比如Add to Shopping Basket 放入购物篮的具体动作:

复合结构图/Composite Structure

状态机图/State Machine Diagram

这是描述图书订购系统如何登录的状态机图

活动图/Activity Diagram

常见的活动图

带泳道活动图

将活动分组,明确该组活动负责的对象,对象负责该组的全部活动

子活动图

活动图中,某几个活动可以组成一个内聚的子活动。

可中断活动图

这里的中断并不严谨,本图中表示这个活动事物是可以取消的。

封装图/包图/Package Diagram

构件图/ Component Diagram

用以描述构件之间的相互关系。

部署图/Deployment Diagram

总结一下

本文走马观花的将UML大致梳理了一下,并结合EA的例图,将常见的UML图的作用大致描述一遍,供大家参考。对于软件开发人员而言,UML还是很有必要学习掌握的。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • UML
    UML
    +关注

    关注

    0

    文章

    122

    浏览量

    30872
  • 可视化系统
    +关注

    关注

    0

    文章

    30

    浏览量

    2198

原文标题:程序猿都应学习的语言:看25张图学UML

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    “碰一下”支付背后的4G技术

    不知道你是否有留意,近期,在线下支付场景中,多了个支付宝“碰一下”支付的设备,只需要“解锁手机—碰一下—确认”即可完成支付,对比打开付款码支付,步骤确实更加简洁。
    的头像 发表于 01-03 16:27 325次阅读

    支付宝发布新代AI视觉搜索“探一下

    支付宝近日正式推出了基于自研多模态大模型技术的新代AI视觉搜索产品——“探一下”。这创新产品的问世,标志着支付宝在AI技术应用领域迈出了重要步。 “探
    的头像 发表于 12-31 10:49 137次阅读

    请问一下LM4951A与LM4951的区别在哪里?

    请问一下LM4951A与LM4951的区别在哪里? 我们有LM4951替换LM4951A后,产品出现POP和CLICK音的问题。 LM4951的原理见附件。
    发表于 10-18 06:27

    欢创播报 支付宝“碰一下”正式发布

    1 支付宝“碰一下”正式发布 近日,在支付宝开放日上,支付宝宣布升级条码支付体验,推出“支付宝碰一下”,用户无需展示付款码,解锁手机碰一下商家收款设备,最快步完成支付。据介绍,“碰
    的头像 发表于 07-11 11:32 904次阅读
    欢创播报  支付宝“碰<b class='flag-5'>一下</b>”正式发布

    做了个工控项目,拿下3500元奖金!它好在哪?分析一下这个有趣的设计

    先了解一下……模拟量采集器干啥用的?模拟量采集器主要应用于各种信号采集场景,例如:汽车测试、环境监测、工业控制、电赛题练习等。可以物理量的模拟信号转换成数字信号,
    的头像 发表于 06-24 08:04 96次阅读
    做了个工控项目,拿下3500元奖金!它好在哪?分析<b class='flag-5'>一下</b>这个有趣的设计

    技术分享 | AEC-Q007中组件焊点开裂原因分析及相关车规标准介绍

    本文系统梳理了焊点开裂典型失效模式、失效机理,理了AEC-Q007及业内日系、德系等主机厂对应检验标准。
    的头像 发表于 06-11 16:06 4068次阅读
    技术分享 | AEC-Q007中组件焊点开裂原因分析及相关车规标准介绍

    请教一下这个原理是工作原理是什么啊

    麻烦帮忙讲一下这个原理的工作原理 当NTC温度过高的时候 358自动输出电压从20V降低到8V!
    发表于 06-05 15:27

    总结一下LM317的几种经典应用电路

    说起LM317,我们做硬件的都很熟悉了,它是LDO的种,并且输出电压很容易通过外部电阻进行调整,今天总结一下LM317的几种经典应用电路。
    的头像 发表于 05-01 10:07 5865次阅读
    总结<b class='flag-5'>一下</b>LM317的几种经典应用电路

    一下通过采用HPC方法来解决汽车行业工程挑战的两个具体实例

    大家可能都知道,Ansys解决方案与高性能计算(HPC)相结合,可带来巨大的投资回报(ROI)。接下来,让我们来看一下通过采用HPC方法来解决汽车行业工程挑战的两个具体实例。
    的头像 发表于 03-12 14:29 589次阅读

    超级电容了解一下行车记录仪和应急启动电源?

    超级电容了解一下行车记录仪和应急启动电源?它们无一例外都采用了“高倍率”锂电池,特点是放电功率比普通锂电高很多,缺点是比普通锂电还要短命(充放电循环次数更低)。你以为它的结局就是“过劳死”吗?不!从
    的头像 发表于 03-11 08:59 1474次阅读
    超级电容了解<b class='flag-5'>一下</b>行车记录仪和应急启动电源?

    用FreeRTOS 430449程配置了一下基本定时器,为什么进不去中断源,是什么原因?

    用FreeRTOS 430449程配置了一下它的基本定时器,但是它进不去中断源,是什么原因?
    发表于 03-07 08:09

    求助一下

    视频中的这个硬件有无大神能认出来,自己感觉可以用得上,但是不知道叫什么,哎,求助一下各位,是用来夹住个水杯的
    发表于 02-23 22:41

    简单介绍一下电源纹波与电容啸叫

    简单介绍一下电源纹波与电容啸叫  电源纹波与电容啸叫是在电源系统中常见的两种问题,它们会影响电子设备的性能和稳定性。本篇文章详细介绍电源纹波和电容啸叫的定义、原因、对设备的影响以及常见的解决方法
    的头像 发表于 02-04 09:42 1055次阅读

    36张电气控制三菱PLC梯形编程方法汇总

    PLC为,介绍一下PLC梯形编程的方法,希望对大家有所帮助。
    的头像 发表于 01-13 14:30 2743次阅读
    36张电气控制三菱PLC梯形<b class='flag-5'>图</b>编程方法汇总

    aduc842的PSEN和EA引脚是怎么用的?

    aduc842的PSEN和EA引脚是怎么用的?哪位高手帮忙解释,看手册没看明白
    发表于 01-12 07:32