标签:eth oid include 合成 增加 企业 str 软件 其他
也称“类型”,“构造型”。是对UML元素基础定义的扩展,在同一个元素基础定义的基础上赋予特别的含义,使得这个元素适用于特定的场合。是一种扩展手段。
actor是在系统之外与系统交互的某人或某事物,边界之内的所有人和事物都不是参与者。
谁是actor?
用例一定存在actor,可能是一个人,可能是定时器,也可能是一个消息。actor一定是直接并且主动的向系统发出动作并获得反馈的,否则就不是actor。如下几个例子:
机票购买者通过登陆网站购买机票,机票购买者就是actor
机票购买者通过呼叫中心,由人工座席操作定票系统购买机票,人工座席就是actor
机票购买这通过呼叫中心的自动语音预定机票,呼叫中心就是actor
如果让呼叫中心成为订票系统的一个子系统,并且机票购买者可以自主通过人工座席,自动语音,登陆网站预定机票,则机票购买者就是actor,人工座席是业务工人。
业务主角是与业务系统有着交互的人和事务,他们用来确定业务范围。业务主角是参与者的一个版型。业务主角是针对业务人员而非计算机。
记住参与者是在业务系统外的,所以业务系统中的人,就不是参与者。他是主动向系统发出动作的吗?他有完整的业务目标吗?系统是为他服务的吗?
用例的粒度以每个用例能够描述一个完整的事件流为宜,即一个用例描述一项完整业务中的一个步骤。同一个需求阶段,所有的用例粒度都是一个量级的。
actor定义角色,或者:xxx: as yyy 定义角色以及别名
usecase定义用例
可以用-->进行关联,:增加描述
@startuml
usecase 购买机票 as "购买机票\n这里可以添加注释,还可以分行
--
分行
===
再分行"
:机票购买人: as user1
actor 人工座席
user1 -> (购买机票) :网站,自动语音
人工座席 -> (购买机票) : 内部系统
@enduml
结果:
业务实体代表业务角色执行业务用例时所处理或使用的事物。业务实体是参与者在完成其业务目标的过程中使用到的或创建出来的,业务实体必须至少被一个业务场景用例使用或者创建,业务实体是类的一个版型,具有对象的所有性质,包括属性和方法,且只应当包含它本身固有的特性。
主要作用是容纳并为其他元素分类,可以容纳任何UML元素。
避免双向依赖或者循环依赖,依赖关系应该是单向的。
层:分类软件中的层次,可以描述软件的架构信息。
在相关的业务对象有明显的独立性要求,即它们可能在各自的领域类发展变化,但又希望互不影响
一个好的边界类的特点:
边界类必须要知道其他对象类型的需求,以便他们能够得以实施,并相对于系统内部元素保持其可用性和有效性
控制类用于对一个或几个用例所特有的控制行为进行建模。在边界类访问实体类,实体类访问其他实体类时,建议使用控制类。
实体类用于对必须存储的信息和相关行为建模的类。实体对象用于保存和更新一些现象的有关信息。从架构角度上来说实体类位于数据持久层。
设计类是系统实施中一个或多个对象的抽象,设计类所对应的对象取决于实施语言。设计类用于设计模型中,它直接使用与编程语言相同的语言来描述。
@startuml
'直接可以使用class的定义方式写
class Dummy {
String data
void methods()
}
class Flight {
flightNumber : Integer
departureTime : Date
int fun1()
String fun2()
}
note "这是注释" as N2
Flight .. N2
Dummy <|--- Flight
@enduml
结果:
关联关系用一条直线表示,描述不同对象之间的结构关系。关联关系是描述对象之间静态的,天然的结构。
' A 关联B
@startuml
class A {
}
class B {
}
A -- B
@enduml
依赖关系是用一条带箭头的虚线表示,描述一个对象在运行期会使用到另一个对象的关系。
@startuml
' B 依赖 A
class A {
}
class B {
}
A <.. B
@enduml
扩展关系是用一条带箭头的虚线加版型<< extends >>来表示的。它特别用于在用例模型中说明基本用例中的某个扩展点插入扩展用例。
@startuml
' B 扩展出A
usecase A
usecase B
A <.. B:<<extends>>
@enduml
如打电话时,如果通话过程中收到另一个呼叫,我们可以将当前通话保留而接听另一个通话。在这个场景中,保留通话用例就是打电话用例的一个扩展用例
包含关系用一条带箭头的虚线加版型<< include >>表示。它特别用于用例模型,说明在执行基本用例的用例实例过程中插入的行为段。包含用例总是带有抽象性质的,基本用例控制与包含用例的关系,并可依赖于执行包含用例所的结果。包含用例表示的是必需,而不是可选。它应当在概念用例模型中,通过分析业务用例场景而抽象出关键的必选的核心业务而形成包含用例。
@startuml
' A 包含B
usecase A
usecase B
A ..> B:<<include>>
@enduml
实现关系用带空心箭头的虚线表示。它特别用于在用例模型中连接用例和用例实现,说明基本用例的一个实现方式。
比如缴纳电话费业务的例子,缴纳电话费是一个业务目标,实现途径可能有营业厅缴费,银行缴费,预存话费等,每个用例实现都是同一个业务目标的不同实现过程。
@startuml
usecase 缴纳电话费
usecase 营业厅缴费
usecase 银行缴费
usecase 预存话费
缴纳电话费 <|.. 营业厅缴费
缴纳电话费 <|.. 银行缴费
缴纳电话费 <|.. 预存话费
@enduml
精华关系是用一条带箭头的虚线加版型<< refine >>表示的。它特别用于用例模型,一个基本用例可以分解出许多跟小的关键精化用例,这些更小的精化用例更细致的展示了基本用例的核心业务。精化关系仅仅用于建模阶段。
@startuml
usecase 预存话费
usecase 开立账户
usecase 存入现金
usecase 转账
usecase 支付划帐
预存话费 <.. 开立账户:<<refine>>
预存话费 <.. 存入现金:<<refine>>
预存话费 <.. 转账:<<refine>>
预存话费 <.. 支付划帐:<<refine>>
@enduml
范化关系是一条带空心箭头的直线表示。说明两个对象之间的继承关系。不建议在用例之间使用范化关系。
@startuml
' A 继承自B
class A {
}
class B {
}
A --|> B
@enduml
聚合关系是用一条带空心菱形箭头的直线表示的。聚合关系用于类图,特别用于表示实体对象之间的关系,表达整体由部分构成的语义。整体和部分不是强依赖的,即使整体不存在了,部分依然可以存在。
@startuml
' A聚合到B上,或者说B由A组成
class A {
}
class B {
}
A --o B
@enduml
组合关系用一条带实心菱形箭头的直线表示。组合关系用于类图,特别用于表示实体对象关系,表达整体拥有部分的语义。比如母公司拥有许多子公司。组合关系是一种强依赖的特殊聚合关系。如母公司解体了,子公司也将不存在了。
@startuml
' A组合成B, B由A构成
class A {
}
class B {
}
A --* B
@enduml
标签:eth oid include 合成 增加 企业 str 软件 其他
原文地址:https://www.cnblogs.com/luckpiky/p/11441953.html