百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

UML统一建模语言系列二:类图设计方法及最佳实践

yuyutoo 2025-01-03 19:51 1 浏览 0 评论

一、前言


上一篇我们介绍了UML建模语言,旨在通过图形化符号表示系统的结构、行为和交互。这篇我们来介绍其中的UML类图,它是一种重要的静态建模工具,主要用于展示系统的类及其关系。它能够帮助我们清晰地理解系统的结构并进行合理设计。

二、类图的概念


类图是UML中的一种结构图,它主要展示了系统中的类、接口、类的属性与方法以及类与类之间的关系。类图的核心要素包括:

1、类(Class):类是对象的模板,定义了对象的属性和行为。类图中,类以矩形框表示,通常分为三部分:类名、属性、方法。

2、接口(Interface):接口定义了类必须实现的一组操作,通常不包含实现细节,类通过实现接口来遵循约定。接口在类图中通常用带有小圆圈的连接线表示。

3、属性(Attributes):属性是类的字段,表示类对象的状态或数据。属性通常是类的私有成员,外部通过方法访问或修改其值。

4、方法(Methods/Operations):方法是类定义的行为,表示类所能执行的操作。方法通常是公开的,可以通过对象调用。

5、关系(Relationships):类与类之间的关系是类图的关键部分。

类之间的静态关系分为三大类:泛化、关联(基本关联、聚合、组合)、依赖。依次介绍一下:

1、泛化,通常叫做继承(Generalization),这个比较简单,就是我们常用的这个继承类与类之间的一个继承,接口与接口的继承,还有就是类对接口的一个实现,用UML表示法,如上图最左边这两个。继承类与被继承类是一个is-a的关系。

2、关联(Association),这里其实细分了三种:第一个是基本关联,第二个是聚合,第三个是合成也叫组合。然后从左到右是这三种关联关系是依次增强,它们在这个语法上的体现其实就是一个实例变量,一个类拥有另外一个类的实例变量,然后通过这个实例变量可以操作另外一个类的一个属性或方法。它们有三个名字,它们到底有什么区别呢?

首先说基本关联(Association):表示类之间的联系,可以是单向或双向的,常用于表示类之间的交互。

然后说聚合(Aggregation):表示“拥有”的关系,但聚合关系中的类可以独立存在。关联的两个对象,一个代表的是整体,另外一个是代表的是部分。它有这种整体部分的关系,用英文就是has-a的关系。而基本关联它是没有这种关系的,两个对象是没有这种层级结构的。

最后说合成(Composition):是一种强聚合,表示“包含”的关系,其中被包含的类不能独立于包含类存在。它们的关系叫做contains-a的关系。

3、依赖(Dependency):表示类之间的暂时性关系,通常是类的使用关系。代码里面体现局部变量或者说那个方法的入参出参这种形式。

下边我们会通过一个经典的UML类图大家来再熟悉一下:

说明:

1、继承关系: —?(实线 + 空心三角形) 鸟 —? 动物;鸟继承动物。

实现接口: ???? (虚线 + 空心三角形) 大雁 ???? 飞翔;大雁实现了飞翔接口。

实现接口: —○ (棒棒糖表示法) 唐老鸭 —○ 讲人话;唐老鸭实现讲人话接口。

2、关联关系: —> (实线剪头 ) 企鹅 —> 气候;企鹅需要‘知道’气候的变化。

3、依赖关系: ???> (虚线剪头) 动物 ???> 氧气;动物依赖于氧气。

4、聚合关系: ◇—> (空心菱形 + 实线剪头) 大雁 ◆—> 雁群;A是雁群,B是大雁,A包含B,但B不是A的一部分

5、合成关系: ◆—> (实心菱形 + 实线剪头) 大雁 ◇—> 翅膀;部分和整体的关系,如果这个鸟的生命周期结束了,那翅膀其实也就不复存在了。

类与类之间的关系是我们面向对象设计的基本功,需要吃透。

三、为什么使用类图


类图在软件开发中的作用是多方面的,主要包括以下几点:

1、系统结构清晰化:类图能够直观地展示系统的类结构,使开发人员能够轻松理解系统的组成部分及其相互关系。通过类图,开发团队能够更清晰地了解系统的架构和功能划分。

2、促进团队协作:类图是开发团队、产品经理、架构师和测试人员之间沟通的桥梁。它提供了一种统一的语言来表达系统的设计意图,减少了由于理解差异导致的沟通问题。

3、支持重构与维护:随着项目的演进,系统架构可能会发生变化。类图能够帮助开发人员在修改或重构代码时,快速定位系统中的关键类及其关系,从而确保代码的一致性和稳定性。

4、提升软件质量:类图通过明确展示类的职责、方法和关系,帮助开发人员遵循设计原则(如单一职责、组合聚合复用、封装等),从而提高系统的可维护性、可扩展性和稳定性。

5、文档化设计思路:类图是设计文档的一部分,可以记录系统的设计思路,便于后续开发人员理解和维护代码。对于大型项目或团队,类图是理解系统架构的宝贵参考资料。

6、发现潜在问题:通过类图的设计,开发人员可以识别潜在的设计问题,例如类之间的耦合过高、继承体系设计不合理等。及时发现并解决这些问题,有助于提高系统的质量和可维护性。

四、怎么使用类图


设计类图时,应该遵循一定的方法论和最佳实践,确保图表的清晰性和准确性。以下是设计类图的步骤和最佳实践:

4.1、设计步骤

1、需求分析与类识别:根据需求文档、用例图或业务流程,识别系统中需要建模的类。通常,类的识别是通过找出业务领域中的实体、动作或状态来完成的。

2、确定类之间的关系:分析不同类之间的相互作用,确定它们之间的关系。例如,哪些类是继承关系、哪些类通过关联互相交互、哪些类有聚合或组合关系。

3、定义类的属性与方法:为每个类定义必要的属性和方法,确保它们能够支撑系统的功能需求。在此阶段,需要根据功能需求和职责分配来确定类的行为。

4、绘制类图:使用UML建模工具(如drawio、Visio等)绘制类图。确保每个类、接口、属性、方法及关系都清晰标注,并遵循UML标准。

5、验证与评审:完成初步的类图设计后,进行评审。通过与团队成员的讨论,确保类图反映了需求并没有遗漏关键设计元素。在验证过程中,可以发现一些潜在的设计缺陷或不合理的设计。

6、优化与迭代:类图设计是一个迭代的过程。在项目开发的不同阶段,随着需求的变化或系统设计的改进,类图应进行调整和优化。保持类图与实际代码和需求的一致性。

4.1、最佳实践

具体案例:图书管理系统

在设计一个简单的图书管理系统时,可以使用类图来描述其结构。假设系统的需求包括以下功能:

  • 管理书籍(添加、删除、查找)。
  • 管理用户(注册、借阅、归还)。
  • 管理借阅记录(记录借书、还书时间、借阅状态)。

1、识别类:根据需求,我们可以识别出以下主要类:

Book:表示图书,包含图书信息(如书名、作者、isbn)。User:表示用户,包含用户信息(如姓名、ID、借阅历史)。LoanRecord:表示借阅记录,记录每次借书和还书的时间、状态。Library:表示图书馆,包含管理所有书籍和借阅记录的方法。

2、识别关系,并定义类的属性和方法,绘制类图

Book和LoanRecord之间存在一对多关系,一个图书可以有多个借阅记录。Book和LoanRecord类之间通过关联连接。

User和LoanRecord之间也存在一对多关系,一个用户可以有多个借阅记录。User和LoanRecord 类之间通过关联连接。

Library和Book之间存在聚合关系,因为图书馆包含书籍,但图书可以独立存在。


3、 优化与迭代: 根据团队反馈,我们可能需要进一步拆分类、添加更多的功能或者优化类间的关系。

另在设计时遵循设计原则,如:单一职责原则(每个类应该承担明确的职责,避免类承担过多的功能),组合聚合复用原则(就是在一个对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过向这些对象的委派达到复用已有功能的目的。要尽量使用组合/聚合,尽量不要使用继承,避免了继承层次过深或不必要的依赖)等, 从而保证高内聚低耦合。

五、小结


本文介绍了类图的概念(比较重要的一点是对象间的关系),及设计类图的方法和案例实践。类图在实际开发中能够帮助开发团队有效地设计系统的结构,并为软件的后续开发和维护提供清晰的蓝图。

相关推荐

双十二不用愁了,酷炫的PPT数字滚动动画来了,业绩展示更亮眼

试想一下,当在职场路演融资、业绩展示、公开演讲现场使用下面动画特效是不是非常有视觉冲击力呢?但是不是学习了该技巧就能做出震撼感十足的动画特效呢?答案显然是否定的,小编深知PPT的核心能力不在掌握技巧的...

终于等到你,Android 首个滚动截图工具:咔咔截屏录屏大师

寻觅寻觅,总算在Android平台上找到一款支持滚动截图的应用。从此,分享有趣的QQ、微信聊天记录或网页截图时,再也不用一屏屏截图并手动拼接了。和iOS平台盛名的长图不同,咔咔截屏录屏大师并...

PPT怎样设置图片无限循环滚动,设置方法很简单,新手一学就会

如果我们制作的PPT中的图片是动态图片,会自我进行滚动,是不是会让我们的幻灯片播放的效果变得更加出众呢?这里就向大家介绍设置这一效果的方法。一、插入图片1、依次单击“插入”--“图片”--“来自文件...

微信可以发送滚动字幕了,超简单,看一遍就会了

大家好,最近在和朋友聊天的时候,发现他给我发的消息能在屏幕上滚动,废话不多说,来看下效果吧。如果聊天的时候,消息都变成这样,是不是更有趣了呢!想要实现这样的效果,方法非常简单,需要用到一款小程序,根据...

世界首创!我国开创“车轮”卫星运行模式,隔着云层也能测量地面

在航天发射和卫星监测领域,我国又创造了个世界首次——卫星编组以“车轮式编队”运行。今年3月30日18时50分,我国长征二号丁运载火箭在太原卫星发射中心发射升空,成功将宏图一号01组卫星送入预定轨道,...

利用滚动条来制作动态图表,不会的看过来

现在一份数据,要求根据数据来制作任意3天销量的动态图表。制作过程如下:1、插入----滚动条-----出现“十字”时按住鼠标左键向右拖动绘制滚动条----选中滚动条----右键----设置对象格式--...

微信红包数字跳动表情包 微信红包金额随机跳动动图

最近微信里面很流行随机红包,当我们打开红包的时候可以看到数字在跳动。其实这是一个套路啦。微信红包数字跳动怎么弄呢?下文中详细教教大家。微信红包数字金额随机跳动图片表情包随机红包怎么发1.首先我们选择一...

四屏交错滚动教程,更简单快捷的方法教给你

简单的方法制作四屏交错滚动。·先打开醒图软件,进入醒图,选择拼图,需要几张一组就选几张,我选择三张一组,选择三张图片,选择完成。·选择长图拼接,选择纵向拼接,这样三张图片就拼接成一个长图了。·点右上角...

创意最美早上好动态图片带字 免打字夏日早安问候语动态鲜花图片

1、一万个美丽的未来,抵不上一个温暖的现在;每一个真实的现在,都是我们曾经幻想的未来,愿你爱上现在,梦见未来。早安!2、早安,我永恒的爱人,虽然我尚未起床,但思想已经飞到你的身边来了,忽而高兴,忽而忧...

#安全提示每日一图#滚动摩擦。

#安全提示每日一图#滚动摩擦。????

最后一图逼死强迫症,当你上下滚动屏幕时它还会动

今天学校食堂加餐,我的炒菜里居然还有肉尼玛这不一样的吗为了游戏,命都可以不要这少年才是人生赢家叔叔你在干什么当女孩子问男朋友“我今天哪里不一样”时貌似两个礼物都不错啊我也不知道为什么,今天沙发君自己就...

这个动态甘特图,居然是条件格式制作的,老板看了都夸你厉害

Hello,大家好,今天跟大家分享下我们如何在利用Excel制作一个项目进度表,它的本质其实就是一个甘特图,它最大的特点就是表头是动态的,我们可以通过点击【滚动条】让数据动起来,非常适合用于时间跨度比...

如何使用OLED实现滚动效果

前言这篇文章不过多描述OLED工作原理及驱动过程,仅从实用性出发,如何使用OLED实现滚动效果。这里我们以正点原子战舰板OLED实验例程为基础。(本文配套工程文件,在底部下方供大家学习下载。)对于OL...

12月29日问候大家早上好图片动态表情,问候早晨好表情动态祝福语

用清晨的阳光沐浴,给你舒展;用清新的空气洗漱,给你舒心;伴清莹的雨露散步,给你舒情;向美好的一天欢呼,给你舒怀,用快乐的词汇凝聚,给你祝福,祝你在绚丽的晨光中走好每一天。朋友,早安!新的一天开始了,带...

一款不可或缺的截图软件-ShareX

电脑上截图,相信不少小伙伴都是用的微信或QQ内置的功能,其实Windows系统也有自带的截图工具,快捷键Window+Shift+S。...

取消回复欢迎 发表评论: