![UML 序列图简介 为用例逻辑建模_第1页](http://file3.renrendoc.com/fileroot_temp3/2022-1/16/44434213-c503-42eb-ba49-cb966384f6d7/44434213-c503-42eb-ba49-cb966384f6d71.gif)
![UML 序列图简介 为用例逻辑建模_第2页](http://file3.renrendoc.com/fileroot_temp3/2022-1/16/44434213-c503-42eb-ba49-cb966384f6d7/44434213-c503-42eb-ba49-cb966384f6d72.gif)
![UML 序列图简介 为用例逻辑建模_第3页](http://file3.renrendoc.com/fileroot_temp3/2022-1/16/44434213-c503-42eb-ba49-cb966384f6d7/44434213-c503-42eb-ba49-cb966384f6d73.gif)
![UML 序列图简介 为用例逻辑建模_第4页](http://file3.renrendoc.com/fileroot_temp3/2022-1/16/44434213-c503-42eb-ba49-cb966384f6d7/44434213-c503-42eb-ba49-cb966384f6d74.gif)
![UML 序列图简介 为用例逻辑建模_第5页](http://file3.renrendoc.com/fileroot_temp3/2022-1/16/44434213-c503-42eb-ba49-cb966384f6d7/44434213-c503-42eb-ba49-cb966384f6d75.gif)
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、UML 序列图简介 为用例逻辑建模 Scott W. Ambler总裁,Ronin International2001 年 1 月 11 日本文来自 序列图用于为使用方案的逻辑建模。使用方案恰如其名称所揭示的那样 - 描述使用系统的潜在方法。使用方案的逻辑可以是用例的一部分,可能是备选过程。它也可以是整个用例过程,例如由基本行动过程描述的逻辑,或者部分基本行动过程再加上一个或多个替代方案描述的逻辑。使用方案的逻辑也可以是几个用例中包含的逻辑。例如,一个学生在大学入学后,立即参加了三个研习班。序列图以可视方式为系统中逻辑的流程建模,能够让您记载和验证逻辑,这通常用于分析和设计目的。图 1 是“参
2、加研习班”用例的基本行动过程的模型。您可能想要现在打开该图,并在阅读本文时参考它。分类器横贯该图顶部的那些框表示的是分类器或它们的实例 - 通常是用例、对象、类或参与者(往往用长方形表示,但它们也可以是符号)。因为既可以向对象发送消息,又可以向类发送消息(对象通过调用操作来响应消息,而类则通过调用静态操作来响应消息),所以有必要将它们都包括在序列图中。另外,因为参与者在使用方案中发起操作并占据主动地位,因此也要将他们包括在序列图中。对象的标签具有标准 UML 格式 "name: ClassName",其中的 "name" 是可选的。(在图中没有给出名称的
3、对象称为匿名对象。)类标签的格式为 "ClassName",而参与者名的格式为 "Actor Name" - 这些也都是 UML 标准。例如在图 1 中,"Student"(“学生”)参与者的名称为 "A Student",它的标签为原型 <<actor>>。表示 "UI32 Seminar Selection Screen"(“UI32 研习班选择屏幕”)的主要 UI 元素的实例是名称为 ":SeminarSelector"、原型为 <<
4、UI>> 的匿名对象。因为向 "Student" 类发送静态消息 "isEligible(name, studentNumber)",所以在图中标名了该类(名称为 "Student" 的框)。我们稍后再详细说明。在图中,因为 "Student" 的实例在几个地方都用作消息中的参数,所以为它提供了名称 "theStudent"。与之相反,"StudentsFees" 类的实例不需要在图中的其它任何地方引用,因此可以是匿名的。生命线从各个框垂下来的虚线称为对象生命线,
5、表示在对方案建模期间对象的生命跨度。生命线上的细长框是方法调用框,表明正在由目标对象类执行处理,以完成消息。方法调用框底部的 X 是一种 UML 约定,表明对象已从内存中除去,这通常是接收到原型为 <<destroy>> 的消息的结果。为消息建模消息以带有标签的箭头表示。当消息的源和目标为对象或类时,标签是响应消息时所调用方法的签名。不过,如果源或目标中有一方是人类参与者,那么消息就用描述正在交流的信息的简要文本作为标签。例如,":EnrollInSeminar" 对象向 "Seminar" 的实例发送消息 "isEli
6、gibleToEnroll(theStudent)"。请注意我是如何同时包含方法名和参数名的(如果有参数名,则传递给它)。图 1 还表明 "Student" 参与者通过标签为 "name"(“姓名”)和 "student number"(“学号”)的消息向 ":SecurityLogon" 对象提供信息。(这些实际上并不是消息;它们实际上是用户交互。)返回值可以使用带有表明是返回值标签的虚线箭头表示。例如,标出了从 "Student" 类返回的,作为调用消息结果的返回值 "t
7、heStudent",而没有标出向 "seminar" 发送消息 "isEligibleToEnroll(theStudent)" 的结果的返回值。我的风格是,当返回内容很明显时不标出返回值,这样就不会把序列图搞乱。(您可以发现,序列图可以很快变得相当复杂。)消息实现用例步骤的逻辑,图的左侧概括了这些步骤。请注意,由于步骤的描述往往太过冗长,以至于无法恰当地放在一张图上,因此并没有对用例步骤使用确切的措辞。关键是,步骤号要与用例中的步骤号对应起来,使图的读者能够清楚地了解步骤的大体思想。下面列出的是图 1 所显示的 UML 序列图“参加研习班”
8、用例的基本行动过程。“参加研习班”用例 名称:参加研习班标识:UC 17描述:允许有资格的学生参加研习班。前提:是在校注册学生。结果:在学生有资格且有空位的条件下,允许该生参加他想参加的课程。扩展:N/A包含:N/A继承自:N/A基本行动过程:1. 学生想参加研习班。 2. 学生通过“UI23 安全登录屏幕”将他的姓名和学号输入系统。 3. 系统根据“BR129 确定参加资格”商业规则来验证该学生是否有资格参加学校里的研习班。 4. 系统显示可供选择的研习班列表“UI32 研习班选择屏幕”。 5. 学生指定他想参加的研习班。 6. 系统根据“BR130 确定学生参加研习班的资格”商业规则来验证
9、该学生是否有资格参加研习班。 7. 系统根据“BR143 验证学生研习班课程表”商业规则来验证研习班是否适合该学生的现有课程表。 8. 系统根据课程目录中公布的费用、适用的学生费用和适用的税款来计算研习班的费用。应用“BR 180 计算学生费用”和“BR45 计算研习班税款”商业规则。 9. 系统通过“UI33 显示研习班费用屏幕”显示费用。 10. 系统询问该学生是否仍然想参加研习班。 11. 学生表明他想参加研习班。 12. 系统招收该生参加研习班。 13. 系统通过“UI88 研习班注册摘要屏幕”通知该学生注册成功。 14. 系统根据商业规则“BR100 为学生开具研习班帐单”给该学生开
10、出参加研习班费用的帐单。 15. 系统询问该生是否想打印注册报告书。 16. 学生表明他想打印报告书。 17. 系统打印注册报告书 -“UI89 注册摘要报告书”。 18. 当学生拿到打印的报告书后,用例结束。 备选过程 A:学生没有资格参加研习班1. 系统确定学生没有资格参加研习班。 2. 系统通知该生,他没有资格参加研习班。 3. 用例结束。 备选过程 B:学生不具备前提条件1. 系统确定学生没有资格参加他所挑选的研习班。 2. 系统通知该生,他不具备前提条件。 3. 系统通知该生他所需的前提条件。 4. 用例返回至基本行动过程的第 4 步继续。 备选过程 C:学生决定不参加现有的研习班1
11、. 学生在查看了研习班的列表之后,发现没有他想要参加的研习班。 2. 用例结束。 参考资料 · The Object Primer 2nd Edition,由 Scott W. Ambler 著。New York: Cambridge University Press, 2001。 · The Unified Process Inception Phase,由 Scott W. Ambler 和 Larry L. Constantine 合著。Gilroy, CA: R&D Books, 2000。 · The Unified Modeling Language Referenc
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 七年级语文上册第4单元第20课《虽有佳肴》教学设计及反思(新版)新人教版
- DB 3705T 47-2024黄河口滩区肉羊繁育技术规范
- 二手房买卖合同范本解析
- 个人与公司委托代缴公积金合同范本
- 中小企业借款合同模板
- XX公司委托培训合同
- 中铁物资商城采购合同新范本
- 上海市临时劳动合同模板
- 个人投资入股合同范例
- 不动产行纪买卖合同书
- 年产30万吨高钛渣生产线技改扩建项目环评报告公示
- 民谣酒吧项目创业计划书
- 2023年珠海市招考合同制职员笔试参考题库(共500题)答案详解版
- 心电监护考核标准
- 特种行业许可证申请表
- 古典芭蕾:基本技巧和术语
- 内地居民前往香港或者澳门定居申请表
- DB43-T 2612-2023林下竹荪栽培技术规程
- 三下《动物的一生》教材解读
- 神木市孙家岔镇神能乾安煤矿矿山地质环境保护与土地复垦方案
- 非煤矿山安全应急预案
评论
0/150
提交评论