类在类图中的表示
一、概览
1.plant UML语法学习小结
2.班级学生管理系统中的 —— “学生” 类的属性、方法
3.类图脚本程序
4.类图示例
二、类图语法学习小结
1.类之间的关系
通过某些符号定义 ,例如<|--、*--等符号。
示例1:
@startuml
wtl01 <|-- wtl02
wtl03 *-- wtl04
wtl05 o-- wtl06
wtl07 .. wtl08
wtl09 -- wtl10
@enduml
2.关系上如何添加标识
(1)在关系之间使用标签来说明时, 使用 :
后接 标签文字,可以在每一边使用 ""
来说明元素。
示例2:
@startuml
Class01 "wtl" *-- "wtl" Class02 : contains
Class03 o-- Class04 : wtl
Class05 --> "wtl" Class06
@enduml
(2)在标签的开始或结束位置添加<
或 >
以表明是哪个对象作用到哪个对象上。
示例3:
@startuml
class Car
Driver - Car : drives >
Car *- Wheel : have 4 >
Car -- Person : < wtl
@enduml
3.如何添加方法
(1)为了声明域或者方法,可以使用后接域名或方法名,系统检查是否有括号来判断是方法还是域。
示例4:
@startuml
Object <|-- ArrayList
Object : wtl()
ArrayList : Object[] elementData
ArrayList : wtl()
@enduml
(2)同样可以可以使用{}
把域或者方法括起来
示例5:
@startuml
class wtl {
String data
void methods()
}
class wtl {
flightNumber : Integer
departureTime : Date
}
@enduml
4.抽象和静态
通过修饰符{static}
或者{abstract}
,可以定义静态或者抽象的方法或者属性,这些修饰符可以写在行的开始或者结束。也可以使用{classifier}
这个修饰符来代替{static}
。
示例6:
@startuml
class wtl {
{static} String name
{abstract} void methods()
}
@enduml
5.高级类体
PlantUML中默认自动将方法和属性重新分组,当然也自己定义分隔符来重排方法和属性,例如:--
..
==
__
,我们还可以在分隔符中添加标题。
示例7:
@startuml
class wtl {
You can use
several lines
..
as you want
and group
==
things together.
__
You can have as many groups
as you want
--
End of class
}
class name {
.. Simple Getter ..
+ getName()
+ getAddress()
.. Some setter ..
+ setName()
__ private data __
int age
-- encrypted --
String password
}
@enduml
6.备注和模板
模板通过类关键字("<<"和">>")来定义,可以使用note left of
, note right of
, note top of
, note bottom of
这些关键字来添加备注,你还可以在类的声明末尾使用note left
, note right
,note top
, note bottom
来添加备注。
示例8:
@startuml
class age << general >>
Object <|--- ArrayList
note top of Object : my age is 22
note "This is a table" as N1
Object .. N2
N2 .. ArrayList
class name
note left: my name is wtl
@enduml
7.如何给链接写注释
定义链接之后,用 note on link
给链接添加注释。
示例9:
@startuml
class student
student --> name : A link
note on link #red: name is wtl
student --> age : Another link
note right on link #blue
age is 22
end note
@enduml
8.如何使用非字母字符
如果你想在类(或者枚举)的显示中使用非字母字符,可以在类的定义中使用 as
关键字,或者在类名旁边加上 ""
示例10:
@startuml
class "This is my class" as class1
class class2 as "It works this way too"
class2 *-- "foo/dummy" : use
@enduml
9.隐藏属性、函数和类
基础命令是: hide empty members
. 这个命令会隐藏空白的方法和属性,可以使用 show/hide
命令来定义相关规则和例外,也可以使用 show/hide
命令来隐藏类。
示例11:
@startuml
class name {
+myMethods()
}
class age {
+hiddenMethod()
}
class school <<Serializable>> {
String school
}
hide members
hide <<Serializable>> circle
show Dummy1 methods
show <<Serializable>> fields
@enduml
示例12:
@startuml
class name
class school
name *-- school
hide school
@enduml
10.类的泛型的定义
你可以用 <
>
来定义类的泛型。
示例13:
@startuml
class name<? nam is wtl> {
int size()
}
name *- student
@enduml
11.声明包
可以通过关键词 package
声明包,同时可选的来声明对应的背景色(通过使用html色彩代码或名称)。
示例14:
@startuml
package "student" #DDDDDD {
wtl <|-- name
}
package student.uml {
wtl <|-- age
}
@enduml
15.设计包的样式
可以通过以下的命令来设置默认样式 : skinparam packageStyle
,或者对包使用对应的模板。
示例15:
@startuml
scale 750 width
package foo1 <<Node>> {
class Class1
}
package foo2 <<Rectangle>> {
class Class2
}
package foo3 <<Folder>> {
class Class3
}
package foo4 <<Frame>> {
class Class4
}
package foo5 <<Cloud>> {
class Class5
}
package foo6 <<Database>> {
class Class6
}
@enduml
16.改变箭头方向
类之间默认采用两个破折号 --
显示出垂直方向的线. 要得到水平方向的可以像这样使用单破折号 (或者点)。
示例16:
@startuml
student o- name
student *-- age
@enduml
二、“学生” 类的属性、方法
属性有: 学生基本信息(姓名,学号,年龄,班级,职务)
学生课程信息(课程名,上课教室,老师姓名)
学生成绩信息(学号,姓名,成绩)
三、plant uml 脚本程序
@startuml
class 学生个人信息 {
-姓名:string
-学号:varchar
-年龄:varchar
-班级:string
-职务:string
__
+登录
+修改个人信息
+退出登录
}
class 学生课程信息{
-课程名:string
-教室:string
-老师:string
__
+登陆
+选课
+退出
+查看课程
+课程成绩
}
class 学生成绩 {
-学号:varchar
-姓名:string
-成绩:varchar
__
+登陆
+查看成绩
+退出
}
学生课程信息 --> 学生个人信息
学生成绩-left-> 学生个人信息
@enduml
四、类图示例