版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第5章系统动态建模-活动图2023/8/21第5章系统动态建模-活动图2023/8/11理解:活动图的作用掌握:活动图建模的方法教学要求2023/8/22理解:活动图的作用教学要求2023/8/125.1活动图的概念5.2活动图的表示5.3活动图分类5.4构建活动图小结2023/8/235.1活动图的概念5.2活动图的表示5.3活动图分活动(Activity)是做某件事情的状态,它可以是现实世界中的一项工作,如写文章、修机器等;或者是执行某个软件的例行程序,如运行对象类中的一个操作等。
活动图是一种表述业务过程以及工作流的技术。它可以用来对业务过程,工作流建模,也可以对用例实现,甚至是对程序实现进行建模。活动图与流程图的最主要的区别在于,活动图能够标识活动的并行行为。5.1定义活动图2023/8/24活动(Activity)是做某件事情的状态,它可以是现实世界活动是某件事情正在进行的状态。它既可以是现实生活中正在进行的某一项工作(写文章、维修机器等)也可以是软件系统中正在运行的某个类对象的一个操作。活动具体表现为由一系列动作组成的执行过程。将各种活动以及不同活动之间的转换用图形进行表示,就构成了活动图。5.1定义活动图2023/8/25活动是某件事情正在进行的状态。5.1定义活动图2023/8活动图描述了活动的顺序,展现从一个活动到另一个活动的控制流。活动图在本质上是一种流程图。但与流程图又有区别。5.1定义活动图2023/8/26活动图描述了活动的顺序,展现从一个活动到另一个活动的控制流。活动图与流程图的区别活动图描述系统使用的活动、判定点和分支,看起来和流程图没什么两样,并且传统的流程图所能表示的内容,大多数情况下也可以使用活动图表示,但是两者是有区别的,不能将两个概念混淆。2023/8/27活动图与流程图的区别2023/8/17活动图与流程图的区别⑴流程图着重描述处理过程,它的主要控制结构是顺序、分支和循环,各个处理过程之间有严格的顺序和时间关系活动图描述的是对象活动的顺序关系所遵循的规则,它着重表现的是系统的行为,而非系统的处理过程。2023/8/28活动图与流程图的区别⑴流程图着重描述处理过程,它的主要控制⑵活动图能够表示并发活动的情形,而流程图不能。⑶活动图是面向对象的,而流程图是面向过程的。活动图与流程图的区别2023/8/29⑵活动图能够表示并发活动的情形,而流程图不能。活动图与流程5.2活动图的表示1.活动图活动图是描述系统或业务的一序列活动构成的控制流,它描述了系统从一种活动转换到另一种活动的整个过程。例如,有一个表示某公司销售过程的一张活动图,图8-1就是描述这一业务过程的活动图。图8-1活动图2023/8/2105.2活动图的表示1.活动图图8-1活动图2023/8/5.2活动图的表示2.活动图的作用活动图常用来描述业务或软件系统的活动轨迹,描述了系统的活动控制流程。我们常用活动图对业务过程、工作流和用例实现进行建模。3.活动图的组成元素活动图的元素包括初始节点、终点、活动节点、转换、分支、分岔与汇合。其中,转换、分支、分岔与汇合把多个活动节点连接在一起。4.活动图与交互图活动图和交互图是UML中对系统动态方面建模的两种主要形式,交互图强调对象与对象之间的交互消息,而活动图则强调的是从活动到活动的控制流程.2023/8/2115.2活动图的表示2.活动图的作用2023/8/111
1.活动图的元素活动起点活动分叉汇合活动终点分支合并2023/8/2121.活动图的元素活动起点活动分叉汇合活动终点分支合并
1、活动的概念表示工作流过程中命令的执行或活动的进行。2、活动的符号一、活动(动作)2023/8/2131、活动的概念一、活动(动作)2023/8/2、活动的符号在下图中列出的就是一些可能的活动节点描述,可能用文字描述活动节点,可能用表达式描述活动节点,可能用消息描述活动节点。图活动节点2023/8/2142、活动的符号在下图中列出的就是一些可能的活动节点描述,可能二、状态开始状态结束状态2023/8/215二、状态开始状态结束状态2023/8/115一个活动图中开始状态能否有多个?结束状态能否有多个?2023/8/216一个活动图中开始状态能否有多个?结束状态能否有多个?2023注意:一个活动图中只能有一个开始状态一个活动图中可以有多个结束状态2023/8/217注意:2023/8/117三、转移(动作流)活动之间、活动与状态之间的转换。2023/8/218三、转移(动作流)2023/8/118四、分支与合并在实际应用中,有三种活动控制流,它们是顺序结构、分支结构、循环结构.当从一个活动节点到另一个活动节点的转换需要条件时,常用分支与监护条件来表示活动的分支结构.分支是用菱形表示的,它有一个进入转换(箭头从外指向分支符号),一个或多个离开转换(箭头从分支符号指向外)。而每个离开转换上都会有一个监护条件,用来表示满足某种条件时才执行该转换。一个合并有两个带条件的入转换和一个出转换,合并表示从对应的分支开始的条件行为的结束。2023/8/219四、分支与合并在实际应用中,有三种活动控制流,它们是顺序
1、分支根据条件的取值决定动作的流向。2023/8/2201、分支2023/8/1202023/8/2212023/8/1212023/8/2222023/8/122分支的两种表示方法2023/8/223分支的两种表示方法2023/8/1232、合并合并将两条路径连接到一起,合并成一条路径。2023/8/2242、合并2023/8/124提示:判断节点与合并节点的符号相同2023/8/225提示:判断节点与合并节点的符号相同2023/8/125五、分叉和汇合在实际应用中,如果活动的转换是有条件的,我们就用分支与监护条件来表示转换,如果一些活动是并发执行的,我们就用分叉和汇合来表示并发活动。分叉线和汇合线都使用加粗的水平线或垂直线段表示。2023/8/226五、分叉和汇合在实际应用中,如果活动的转换是有条件的,我1、分叉用于将一个控制流分为两个或多个并发运行的分支。2023/8/2271、分叉2023/8/1272023/8/2282023/8/1282、汇合用于将两个或多个控制流合并到一起形成一个单向控制流。如果一个控制流在其他控制流到达之前到达了连接,它将会等待,直到所有控制流都到达了才会向连接传递控制权。2023/8/2292、汇合如果一个控制流在其他控制流到达之前到达了连接,它将会2023/8/2302023/8/130(1)分叉:每个分叉可以有一个输入转换和两个或多个输出转换,每个转换都可以是独立的控制流。(2)汇合:当两个或多个并发控制流都达到汇合点后,活动流程才能进入下一个活动节点.分岔用来表示两个或者多个并发活动的分支;而汇合则用于同步这些并发活动的分支,当且仅当所有的并发分支(活动)都到达汇合点后,活动流程才能进入下一个活动节点。2023/8/231(1)分叉:每个分叉可以有一个输入转换和两个或多个输出转换,活动图课堂练习大家画一下用word创建一个文件的活动图,使用该活动图对这一过程进行建模。打开新建保存文件名输入内容选择是否需要图形软件保存打印2023/8/232活动图课堂练习大家画一下用word创建一个文件的活动图,使2023/8/2332023/8/133练习2:学生选课学生进入选课系统提交自己的用户名和密码系统验证用户名如果用户名不存在,给出提示结束如果用户名存在,检查学生输入的密码如果密码不正确,给出提示结束如果密码正确,系统显示课程列表学生选择要选修的课程学生提交所选的课程系统对选课进行验证,并给出确认提示学生确认后,系统保存所选课程系统提示操作成功学生退出选课系统2023/8/234练习2:学生选课学生进入选课系统2023/8/134进入学生选课系统提交用户名和密码系统验证用户名验证用户密码[有]系统显示课程列表学生选择要选修的课程系统验证并确认所选课程保存所选课程退出学生选课系统[没有]提交所选课程[不正确][正确][冲突][不冲突]2023/8/235进入学生选课系统提交用户名和密码系统验证用户名验证用户密码[练习:销售合同从签订到履约的过程销售合同签订后,要进行核对。如果发现错误,则终止履约;如果没有错误,则要核对货物清单确定是否有货,还要核对付款单确定对方是否已经付款,只有这两项都完成,才可以发货。如果无货或对方尚未付款,则终止履约。2023/8/236练习:销售合同从签订到履约的过程2023/8/1362023/8/2372023/8/137课堂练习学生请假流程1、学生请假须先经班主任同意;2、班主任在准假时,如学生请假时间超越审批权限,还要请系办审批,经系办审批后,系办将假条存根留下,事后转班主任存查。3、学生请假获准后,应立即报告班长,以便班长向任课教师报告。2023/8/238课堂练习学生请假流程2023/8/1382023/8/2392023/8/1395.3活动图分类按照活动图表示的信息不同,将活动图分为:简单活动图、标识泳道的活动图、标识对象流的活动图、复合活动图。2023/8/2405.3活动图分类按照活动图表示的信息不同,将活动图分为:5.3.1简单活动图图5-8就是一个描述订单处理的简单活动图,这个图既没有标识活动的执行者,也没有标识活动执行过程中,创建了哪些对象。其中,每个活动都是简单的活动。2023/8/2415.3.1简单活动图图5-8就是一个描述订单处理的简单活图5-8订单处理2023/8/242图5-8订单处理2023/8/142ATM机“登录”用例的活动图2023/8/243ATM机“登录”用例的活动图2023/8/1431.借阅者的活动图图书馆管理系统2023/8/2441.借阅者的活动图图书馆管理系统2023/8/1442.图书管理员的活动图图书馆管理系统2023/8/2452.图书管理员的活动图图书馆管理系统2023/8/1453.系统管理员维护借阅者帐户的活动图图书馆管理系统2023/8/2463.系统管理员维护借阅者帐户的活动图图书馆管理系统2023/4.系统管理员进行书目信息维护的活动图图书馆管理系统2023/8/2474.系统管理员进行书目信息维护的活动图图书馆管理系统20235.系统管理员维护书籍信息的活动图图书馆管理系统2023/8/2485.系统管理员维护书籍信息的活动图图书馆管理系统2023/85.3.2标识泳道的活动图为了有效地表示各个活动由谁负责的信息,可以通过泳道(SwimLane)来实现。例如,在图8-9的活动图中,活动的执行者包括窗口和打印机,因此可以将其分成二个泳道。左边泳道中的所有活动的执行者是窗口;右边泳道中的所有活动的执行者是打印机。每个泳道用一条垂直的线将它们分开,并且每个泳道都必须有一个唯一的名称,例如本例中的窗口和打印机。从图中可以看出,每个活动节点,分支必须只属于一个泳道,而转换,分岔与汇合是可以跨泳道的。通过泳道,不仅体现了整个活动控制流,还体现出了每个活动的实施者。2023/8/2495.3.2标识泳道的活动图为了有效地表示各个活动由谁负责的5.3.2标识泳道的活动图获取打印机数据设置打印页面传送打印数据打印文件初始化打印机保存页面参数数据接收并保存打印数据执行打印命令:窗口:打印机图8-9标识泳道的活动图2023/8/2505.3.2标识泳道的活动图获取打印机数据设置打印页面传5.3.2标识对象流的活动图在活动图中,存在这样一些现象:一种情况是,可能存在一些对象进入一个活动节点,经过活动处理,修改了对象的状态;另一种情况是,活动节点创建或删除了一些对象;一些情况是,输出一些对象。在这些活动中,对象与节点活动是紧密相关的,用户可以在活动图中把相关的对象标识出来,即标识哪些对象进入活动节点,哪些对象从活动节点中输出,这对编程具有现实意义。在UML中,我们可以在活动图中标识一个对象的角色,状态和属性值的变化,它的表示方法如图8-10所示。图8-10活动图中的对象表示法2023/8/2515.3.2标识对象流的活动图在活动图中,存在这样一些现5.3.3标识对象流的活动图2023/8/2525.3.3标识对象流的活动图2023/8/1525.3.3标识对象流的活动图在图8-11中,标识了一些关键的对象流,对象的状态也在图中作了标识:(1)当“用户下订单”时,将创建一个Order类的实例,用来存放订单的信息,该Order类还包含着相应的OrderItem(针对每个产品一条)(2)当“生成送货单”时,将根据Order类的实例创建多个DeliverOrder(送货单)的实例。(3)当“修改订单项状态”之后,DeliverOrder对象的状态将变成finished。2023/8/2535.3.3标识对象流的活动图在图8-11中,标识了一些关5.3.3标识对象流的活动图当然,在这张活动图中实际上还蕴藏着许多对象流,例如:(1)当“收款”后,Order类的实例的状态就变成了“已付款”。(2)当“修改订单项状态”后,Order类中部分订单项的状态就变成了“已送货”。(3)当用户取消或订单超过时限时,Order类的状态就将成为Cancel。在实际应用中,绘制活动图时并不一定需要将所有的对象流都标识出来,这样会使活动图变得复杂、混乱。在实际建模中,只对重要的对象进行描述。2023/8/2545.3.3标识对象流的活动图当然,在这张活动图中实际上还5.3.4标识信号的活动图在交互图中,利用“信号”可以增加活动图的可读性。信号是表示两个对象之间进行异步通讯的方式,当一个对象接收到一个信号时,将触发信号事件。2023/8/2555.3.4标识信号的活动图2023/8/1555.3.4标识信号的活动图1.信号在活动图中,有三种信号元素,它们是:发送信号,接收信号和时间信号,其表示方法如图8-12所示。(1)时间信号:时间信号是用来表示随着时间的流逝而自动发出的信号,时间信号表示,当时间到达某个特定的时刻时,就会触发时间事件,例如每天10点时,闹钟开始响铃,10点钟发出响铃的信号就是时间信号。(2)发送信号:也就是发出一个异步消息,对于发送者而言,就是发送信号;对于接收到这种消息的目标而言,就是“接收信号’。(3)接收信号:就是接收者收到的一个外部信号。图8-12三种信号的表示法2023/8/2565.3.4标识信号的活动图1.信号图8-12三种信号5.3.4标识信号的活动图2.活动图中标识时间信号例如小张去必胜客饭店吃饭,发现要排队等待,他决定如果15分钟还轮不到,就到隔壁的肯德基吃饭,这时就可以通过上述的符号来表示小张吃饭的活动。图8-13中假设小张排在最前面。在“小张”这个泳道中,两个控制流中只有一个会控制流会执行。在时间信号发生之间,收到当必胜客饭店发出“有空位”信号,小张接收到“有空位”信号时,小张才会执行“进入必胜客”的活动;否则小张会执行“进入肯德基”的活动。2023/8/2575.3.4标识信号的活动图2.活动图中标识时间信号2025.3.4标识信号的活动图图8-13信号在活动图中的应用2023/8/2585.3.4标识信号的活动图图8-13信号在活动图中的应5.3.5标识参数的活动图一个方法可以包含多个参数,一个活动节点也可能带有多个参数。在绝大多数情况下,并不需要在活动图上标明参数信息,如果打算标明每个活动节点执行前,需要输入哪些参数,活动节点执行后,需要输出哪些参数,以及活动节点执行后,要进行的错误处理。这时,在活动图中标明参数,使活动图表示更多的信息。1.参数参数是一个对象节点,用一个小矩形框表示。参数分三种:输入参数,输出参数,错误参数。参数都标识在活动节点的边界上,输入参数标识在活动节点的左边界上;输出参数和错误参数标识在活动节点的右边界上。参数有名称和序号,我们把参数名称和号标识在参数节点的旁边。如图8-14所示。2023/8/2595.3.5标识参数的活动图一个方法可以包含多个参数,一5.3.5标识参数的活动图在图8-14中,它表示活动“计算利息”节点将接受三个输入参数:本金(principal)、利率(rate)、年限(year);如果传入的参数合法,那么将输出参数利息值(accrual);如果输入了错误的参数,则产生异常。在这个例子中,在小矩形中添加箭头符号,以区别输入参数和输出参数的不同。可以直接在参数边上标注表示参数顺序的数字。例如在本图中,principal、rate和year分别是第1、2、3个参数。另外,如果输出产生异常对象,则可以在符号边上标注一个空心三角形。图8-14标识活动节点的输入参数和输出参数2023/8/2605.3.5标识参数的活动图图8-14标识活动节点的5.3.6标识扩展区的活动图在活动图中,有时需要表示一个活动需要多次执行的情况。例如在图8-8中,有三个活动节点“供应商送货”,“修改订单项状态”以及分支“所有订单项已送货完毕”都需要多次执行。由于一个订单对应多个“送货单”,因此在图8-8中,通过“分支”来表示其循环控制流,这样表示活动,并不准确。在图8-15中,我们采用了扩展区来表示活动节点的循环执行。2023/8/2615.3.6标识扩展区的活动图在活动图中,有时需要表示一个活5.3.6标识扩展区的活动图图8-15用扩展区表示活动节点的循环执行2023/8/2625.3.6标识扩展区的活动图图8-15用扩展区表示活动例:一个名为“招聘处理”的扩展区域图
扩展区域与并发行为示例
招聘处理求职申请检查申请资料审定聘用资格面试人事安排申请表[聘用][不聘]聘用表<<Concurrent>>2023/8/263例:一个名为“招聘处理”的扩展区域图扩展区域与5.3.7嵌套活动图如果一个活动图又包含了子活动图,则称这种图为嵌套活动图(也称为主活动图)。当一个活动图很复杂,我们可以把其中的一组相关活动看作一个子活动图,这时,在嵌套活动图中,用子活动图的简图代替子活动图。我们可以将子图单独放在一个图中详细说明它的活动,然后,在嵌套活动图引用子活动图。图8-15是一个嵌套活动图,其中的收款(活动)又是一个子活动图,子活动图的详细说明如图8-16所示。图8-16子活动图说明:一般来说,我们在嵌套活动图中,用叉齿符号的子图(子活动图的简图)来代替子活动图。2023/8/2645.3.7嵌套活动图如果一个活动图又包含了子活动图,则称组合活动“发货”用一个子活动图表示,它有自己的初始状态、终结状态和判定分支。Home2023/8/265组合活动“发货”用一个子活动图表示,它有自己的初始状态、终结5.4构建活动图活动图主要应用对两个方面建模:一是在业务分析阶段,对工作流程进行建模;二是在系统分析和设计阶段,对操作流程进行建模。2023/8/2665.4构建活动图活动图主要应用对两个方面建模:一是在业务5.4.1对工作流程建模用活动图对业务流程建模时,活动图中,每一条泳道表示一个职责单位(可以是个人,也可以是一个部门),每个泳道的执行者(或职责人)体现了职能部门的工作职责、业务范围、部门之间的交互关系。
说明:矩形代表活动,菱形代表判断,平行线代表并行操作,带箭头线代表活动流,每个大列代表一个职能部门,最左边的每个分块代表业务阶段。2023/8/2675.4.1对工作流程建模用活动图对业务流程建模时,活动5.4.1对工作流程建模使用活动图来对工作流程进行建模时,应该遵循以下一些主要原则:1.从整个工作流中,选出一部分能体现高层职责的部门,并为每个重要的职责部门创建一条泳道2.标识工作流初始节点的前置条件和活动终点的后置条件,以便有效地找出工作流的边界。3.从该工作流的初始节点开始,找出随时间推动的动作和活动,并在活动图中把它们标识成活动节点.4.将复杂的活动或多次出现的活动用一个或多个子活动图的引用节点表示,然后为每个被引用的子活动图绘制出的详细活动图。5.找出连接这些活动节点的转换,首先从工作流的顺序开始,然后考虑分支,接着再考虑分岔和汇合6.如果标识出工作流中重要的对象,则也可以把对象流加入到活动图中7.若工作流中有重复执行的活动,我们采用扩展区来表示循环活动2023/8/2685.4.1对工作流程建模使用活动图来对工作流程进行建模例:一个表示软件开发的精化阶段的工作流的活动图,如图所示。它不是一个完全的活动图,在图中没有泳道和对象流,但它是现实的软件开发工作流的一个简化的可视化的描述。Home2023/8/269例:一个表示软件开发的精化阶段的工作流的活动图,如图所示。5.4.2对操作流程建模在系统设计期间,我们用活动图对对象的职责进行建模,这时,这时,每一个对象占据一个泳道,而活动是该对象的成员方法。在系统分析设计阶段,采用带泳道的活动图的情况较少,因为顺序图会更好地体现对象间的交互关系。活动图更适合于对其流程进行概述,最常用的场景是通过活动图对用例描述中的事件流进行建模。当用例的事件流较复杂,分支较多时,一张清晰明了的活动图能够帮助开发人员更好地理解程序的逻辑。2023/8/2705.4.2对操作流程建模在系统设计期间,我们用活动图对对5.4.2对操作流程建模用活动图对操作进行建模时,应遵循以下原则:1.寻找操作所涉及的属性,包括操作的参数、返回类型、所属类的属性以及某些邻近的类
2.识别该操作的初始节点的前置条件和活动终点的后置条件。也要识别在操作执行过程中必须保存的信息.3.从该操作的初始节点开始,标识随着时间发生的活动,并在活动图中将它们表示为活动节点
4.如果需要,使用分支来说明条件语句及循环语句
5.仅当操作属于一个主动类时,才在必要时用分岔和汇合来说明并行的控制流程.2023/8/2715.4.2对操作流程建模用活动图对操作进行建模时,应遵循5.5.1如何建模活动图(1)定义活动图范围,确定开始、结束状态。(2)添加活动,建模主路径。(3)寻找分支和并行的情况,建模扩展路径。(4)根据需
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025福建宁德市统计局普查中心公开招聘工作人员3人备考考试题库及答案解析
- 2026中国农业科学院第一批统一招聘(中国农科院茶叶研究所)笔试考试备考题库及答案解析
- 2025南平市延平区国有资产投资经营有限公司招聘综合部业务员1人参考笔试题库附答案解析
- 2025广东广州生物院联合生科院张笑人教授课题组科研助理招聘备考考试试题及答案解析
- 2025辽宁沈阳大学和沈阳开放大学面向社会招聘急需紧缺事业单位工作人员21人模拟笔试试题及答案解析
- 2025东方通信股份有限公司核心研发岗位招聘3人备考考试试题及答案解析
- 深度解析(2026)《GBT 25800-2010纺织染整助剂命名原则》(2026年)深度解析
- 2025广东深圳市宝安区翻身实验学校(西校区)诚聘初中地理、初中道法和高中历史教师3人参考笔试题库附答案解析
- 2025河北秦皇岛市社会保险事业服务中心选调6人参考笔试题库附答案解析
- 2026河南省气象部门招聘应届高校毕业生14人(第2号)参考笔试题库附答案解析
- 全员品质意识培训
- 货物代理报关合同范本
- 2025甘肃酒泉市公安局招聘留置看护岗位警务辅助人员30人(第三批)考试笔试备考题库及答案解析
- 2025高中历史时间轴与大事年表
- 《企业纳税实训》课件 第12章 企业所得税
- 2025年大学《新闻学-新闻法规与伦理》考试参考题库及答案解析
- 2025至2030中国精炼橄榄油行业调研及市场前景预测评估报告
- 蓄水池防水施工方案及施工工艺方案
- 培优点05 活用抽象函数模型妙解压轴题 (9大题型)(讲义+精练)(解析版)-2026年新高考数学大一轮复习
- GB/T 23452-2025天然砂岩建筑板材
- 小学美术教育活动方案设计
评论
0/150
提交评论