【程序员高效率工具】PlantUML —— 使用代码快速绘制时序图、思维导图

news2025/1/9 1:36:45

本篇思维导图

在这里插入图片描述

前言

不管是在工作还是学习,特别是在项目计划初期,我们需要画大量的图将工作内容、项目方案等进行可视化描述,包括但不限于时序图、类图、思维导图等等。

但是对于不经常画图,或者经常使用键盘的孩子,手工画图或者使用软件进行画图都是一件比较头疼的操作,特别是像我这种有强迫症的孩子,任何歪歪扭扭的地方都会让我极其不舒服想要将图画的尽量笔直和完美。

所以,如果可以直接敲代码,就可以生成想要的图,对于工作效率和专注度都有极大的提升,另外,将图上的逻辑用代码描述出来,本身就又能加深自己的理解。

好在,我在工作中偶然发现了这样的一个开源项目,PlantUML!!!真的,强烈安利,程序员必备、计算机学生必备,只敲代码,真的是方便了许多,我在画时序图的时候,一个对象可能要画2-3分钟,从找标识到手工对齐,添加对象名,但是用代码只需要一行解决!!!啊,这个优点已经好到必须要亲自体会了!!!强烈安利!!!它已经是我画图时必用的一款神奇,和markdown一样不可忽视。

PlantUML简介

PlantUml是一个开源项目,可以用写代码的方式快速回至出各种自己想要的图。此外,不仅支持画UML,还支持很多常用的,比如思维导图、ER图等等。戳官网:PlantUML

下面我就我自己的使用分享一些简单常用的使用方法

时序图篇

官网使用文档:时序图

  1. 开始和结束

    @startuml表示开始

    @enduml表示结束

  2. 对象表示

    常用对象:

    actor 实体对象,比如人、操作员等

    participant 参与者,可以是类、服务名等

    database 数据库

    queue 队列,比如kafka队列就可以用这个表示

    定义对象:

    格式: 对象类型 对象名 [as 对象别名]

    [ ] 里面的内容为可选项,即可以为对象定义别名,这个别名是为了在代码中引用对象方便,实际图中对象的名字还是我们定义的对象名。

    例子:

    actor 用户 定义一个实体对象,对象名为“用户”

    database mysql 定义一个数据库,名字为“mysql”

    participant SQLServer as db 定义一个参与者,服务名为“SQLServer”,别名为“db”,在代码中可以直接用db表示SQLServer

    queue kafka 定义一个queue对象,名为 kafka

@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka
@enduml

![示例图][image_示例图]

  1. 消息传递

时序图主要是为了展示项目中的数据流走向,因此消息传递是时序图的重要部分。

->表示消息传递走向,默认箭头类型是单向直线,PlantUML手册中有很多样式可以通过代码自定义颜色和样式

-->是单向虚直线箭头,一般是用来传递消息返回信息

用户->mysql: 数据库请求

mysql-->用户: 请求结果

@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka
'消息传递
用户->mysql: 数据库请求
mysql-->用户: 请求结果
@enduml

![消息传递][image_消息传递]

  1. 生命线的激活与撤销

一般完整的时序图中都会包含生命周期,当某个服务被触发,从开始工作到工作结束返回请求的这段时间,就是这个服务当下的生命周期,在PlantUML中,使用activatedeactivate来激活、销毁生命周期

@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka
'消息传递
用户->mysql: 数据库请求
'激活mysql生命线
activate mysql
mysql-->用户: 请求结果
'销毁mysql生命线
deactivate mysql
@enduml

![生命线][image_生命线]

  1. 分支和循环表示

某些复杂情况下需要处理一些分支和循环的内容,PlantUML中用 alt-else-end 表示分支, 用 loop-end表示循环

alt 查询
    用户->mysql: 数据库查询请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
else 插入
    用户->mysql: 数据库插入请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
end
@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka
'消息传递
alt 查询
    用户->mysql: 数据库查询请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
else 插入
    用户->mysql: 数据库插入请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
end
@enduml

![分支][image_分支]

loop 查询1000次
    用户->mysql: 数据库查询请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
end
@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka
'消息传递
loop 查询1000次
    用户->mysql: 数据库查询请求
    activate mysql
    mysql-->用户: 请求结果
    deactivate mysql
end
@enduml

![循环][image_循环]

另外,分支和循环都是可以嵌套的。

  1. 一些更简洁的语法

++可以直接激活生命线

return msg可以结束生命线并返回传递消息msg

4中的代码可以直接写成这样

@startuml
'单引号是代码注释
'对象定义
actor 用户
participant SQLServer as db
database mysql
queue kafka

'激活mysql生命线 & 消息传递
用户->mysql++: 数据库请求
'销毁mysql生命线 & 传递返回结果
return 请求结果
@enduml

思维导图篇

目前据官网,这个正在开发中,某些语法可能会发生变化,但是先用着不是?官网手册:思维导图

1. 开始和结束

@startmindmap开始

@endmindmap结束

2. 子主题

使用+-新建分支,用符号数量表示层级,+表示分支向右边生长,-表示分支向左边生长

@startmindmap
+ 思维导图
++ 主题1
+++ 子主题1.1
++ 主题2
-- 主题3
--- 子主题3.1
--- 子主题3.2
-- 子主题4
@endmindmap

3.内容多行表示

使用:开始多行内容,;结束多行内容。目前如果要使用:````;只能用*新建分支

@startmindmap
* templates
**: Example1
今天是520
我在公司开心上班
;
@endmindmap

4.颜色改变

没有颜色的思维导图是没有灵魂的

具体语法建议查看官网手册

@startmindmap
<style>
mindmapDiagram {
  .green {
    BackgroundColor lightgreen
  }
  .rose {
    BackgroundColor #FFBBCC
  }
  .your_style_name {
    BackgroundColor lightblue
  }
}
</style>
* Colors
** Green <<green>>
** Rose <<rose>>
** Blue <<your_style_name>>
@endmindmap

UML时序图简介

对于还不清楚什么是UML时序图的同学,可以看下这两篇文章哦

步步为营UML建模系列五、时序图(Squence diagram)

UML序列图总结(Loop、Opt、Par和Alt)

vscode下配置PlantUML

使用VS CODE+PlantUML高效画图

Vscode plantuml UML图 配置使用

vscode下配置好plantuml后,可以使用Alt + D 预览plantuml文档(.uml文件)

如何从vscode导出plantuml图? F1ctrl+shift+p; 选择 PlantUML:导出当前图表;选择导出格式svg;导出即可。[png 对于较大的导出不全]

解决导出png不完整: vscode 打开设置 --> edit settings.json --> 添加如下:

    "plantuml.jarArgs": [
		"-DPLANTUML_LIMIT_SIZE=8129"
	]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/163788.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VMware三种网络模式的摸索

VMware三种网络模式的摸索 文章目录VMware三种网络模式的摸索前言一、桥接模式简要描述拓扑图展示配置测试优缺点二、NAT模式简要描述拓扑图展示配置测试优缺点三、仅主机模式简要描述拓扑图展示配置测试优缺点3.总结前言 注意&#xff1a;所有的测试请关闭虚拟机和主机的防火…

微信小程序 - 实现手机号登录--授权并获取手机号保存至本地

详细代码请见文档最下方&#xff0c;仅供参考&#xff0c;更多需要请查看官方文档 一、 微信官方文档 | 获取手机号 这是服务端的 这是我们前端获取手机号需要给接口传递的两个参数 注意&#xff1a; 参数一&#xff1a;获取access_token需要用到小程序密钥&#xff0c;这个…

你可能不知道的20个Git命令,但真的很实用

如果您曾经浏览过git 手册&#xff08;或 run man git&#xff09;&#xff0c;那么您会注意到 git 的功能比我们大多数人每天使用的要多得多。很多这些命令都非常强大&#xff0c;可以让你的生活更轻松&#xff08;其他命令有点小众&#xff0c;但仍然很高兴知道&#xff09;。…

QT-QStackedWidget多窗口应用

前言&#xff1a; 多窗口应用&#xff0c;例如某微信&#xff0c;页面由1&#xff0c;2&#xff0c;3个布局组成。 1-基本流程 页面1控制页面2&#xff0c;通过选择页面1上的按钮或控件 页面2控制页面3&#xff0c;通过选择页面2上的按钮或控件 2-其中页面2中的页面很…

100、【树与二叉树】leetcode ——105. 从前序与中序遍历序列构造二叉树+106. 从中序与后序遍历序列构造二叉树(C++版本)

106. 从中序与后序遍历序列构造二叉树 题目描述 原题链接&#xff1a;106. 从中序与后序遍历序列构造二叉树 解题思路 中序的特点&#xff1a;左中右&#xff0c;后序的特点&#xff1a;左右中。因此可通过后序序列找到中间结点&#xff0c;然后再根据中间结点&#xff0c;分…

3、关键词与标识符

目录 一、关键词 二、标识符 一、关键词 C语言中有32个关键字&#xff1a; 注意&#xff1a;在C语言中&#xff0c;关键字是不允许作为标识符出现在程序中的。 二、标识符 C语言标识符的命名规则&#xff1a; &#xff08;1&#xff09;所有标识符必须由字母或下画线开头…

KMP算法 看这一篇就够了 图解刨析+代码

目录 问题背景 逐步剖析 KMP如何优化暴力做法 思考 公共前后缀 next数组 如何构建next数组: 代码实现 问题背景 给定一个字符串 S&#xff0c;以及一个模式串P&#xff0c; P 在字符串 S 中多次作为子串出现。 求出模式串 P 在字符串 S 中所有出现的位置的起始下标。 …

说话人识别中的Temporal pooling(时序池化)

概述 Temporal pooling&#xff08;时序池化&#xff09;是说话人识别神经网络中&#xff0c;声学特征经过frame-level变换之后&#xff0c;紧接着会进入的一个layer。目的是将维度为(bs,F,T)(bs,F,T)(bs,F,T)的特征图&#xff0c;变换成维度为(bs,F)(bs,F)(bs,F)的特征向量 …

再不来看看常用的PyCharm快捷键就out了,玩转PyCharm仅此一篇!

最近在学习Python的数据可视化项目&#xff0c;在大学有学过Python&#xff0c;还有一些基础的。目前虽说已经工作&#xff0c;但是兴趣使然&#xff0c;依然想在空闲时间学一些其他技能来充实自己&#xff0c;未雨绸缪&#xff01; 在使用工具的时候&#xff0c;必定会对工具有…

【话题:工作生活】2021年工作总结--这些人,那些事。

Hello Everyone&#xff0c; 我又开始撰写自己的工作总结了。2021年的工作总结&#xff0c;拖得太久&#xff0c;拖得我也不想写了。每次写自己一年的工作总结&#xff0c;总是要耗费我大量的时间与心力&#xff0c;有时&#xff0c;我也真的是心好累。 好了&#xff0c;懒散、…

【人工智能原理自学】隐藏层:神经网络为什么Working

&#x1f60a;你好&#xff0c;我是小航&#xff0c;一个正在变秃、变强的文艺倾年。 &#x1f514;笔记来自B站UP主Ele实验室的《小白也能听懂的人工智能原理》。 &#x1f514;本文讲解隐藏层&#xff1a;神经网络为什么Working&#xff0c;一起卷起来叭&#xff01; 目录一、…

深度学习 11 梯度下降算法改进

数据初始化要点: 1. 梯度下降算法的三种方式: 批量梯度下降法(batch)&#xff0c;即同时处理整个训练集.小批量梯度下降法&#xff08;Mini-Batch &#xff09;每次同时处理固定大小的数据集.随机梯度下降法&#xff08;stochastic gradient descent&#xff09;, 每次随机选…

acwing基础课——约数

由数据范围反推算法复杂度以及算法内容 - AcWing 常用代码模板4——数学知识 - AcWing 基本思想&#xff1a; 首先&#xff0c;约数&#xff0c;又称因数。整数a除以整数b(b≠0)除得的商正好是整数而没有余数&#xff0c;我们就说a能被b整除&#xff0c;或b能整除a。a称为b的…

怎样才能过好这一生?

文章目录1. 日拱一卒&#xff0c;功不唐捐1.1 适当的时候给自己一个奖励1.2 一个人可能走的更快&#xff0c;但一群人才能走的更远1.3 通过一些事情去逼自己一把1.4 从真理中去感悟1.5 当你面临绝路时2. 梦想的意义不在于实现3. 孤独4. 烦恼5. 别总说来日方长6. 忍和韧性7. 事情…

【linux kernel】linux内核重要函数 | do_initcalls

文章目录一、导读二、do_initcalls三、构造section并添加函数&#xff08;3-1&#xff09;构造初始化调用section&#xff08;3-2&#xff09;向section中添加函数四、总结一、导读 在linux内核启动过程中&#xff0c;会向终端打印出很多的日志信息&#xff0c;从这些日志信息…

c++开源协程库libgo介绍及使用

协程这个概念&#xff0c;最近这几年可是相当地流行了。尤其 go 语言问世之后&#xff0c;内置的协程特性&#xff0c;完全屏蔽了操作系统线程的复杂细节。甚至使 go 开发者“只知有协程&#xff0c;不知有线程”了。当然 C也有高性能的协程库&#xff0c;比如我了解到的微信的…

基于微信小程序的企业职工薪资查询系统小程序

文末联系获取源码 开发语言&#xff1a;Java 框架&#xff1a;ssm JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7/8.0 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.3.9 浏览器…

卷积神经网络(CNN)详细介绍及其原理详解

文章目录前言一、什么是卷积神经网络二、输入层三、卷积层四、池化层五、全连接层六、输出层七、回顾整个过程总结前言 本文总结了关于卷积神经网络&#xff08;CNN&#xff09;的一些基础的概念&#xff0c;并且对于其中的细节进行了详细的原理讲解&#xff0c;通过此文可以十…

自动(智能)驾驶 | 4D雷达的数据集

上篇文章分享了关于Oculii 4D雷达的两篇报告。数据集是一个非常重要的研究工具&#xff0c;对于4D雷达领域来说&#xff0c;处于一个研究前沿的位置&#xff0c;鲜有公开的数据集&#xff0c;目前能找到的数据集有&#xff1a; 这些文章中的数据集有不少博主也写过&#xff0c…

S1000D规范导读

S1000D最初是由欧洲航空工业联盟开发的技术出版物规范&#xff0c;它主要为具有较长生命的复杂产品运行和维修而设计。这些年不断发展&#xff0c;已经扩展到这些行业的产品&#xff1a;国防系统 - 包括海、陆、空的产品&#xff0c;民用航空产品&#xff0c;基建行业产品和船舶…