【计算机基础】通过插件plantuml,实现在VScode里面绘制状态机

📢:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨

📢:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852

📢:文章若有幸对你有帮助,可点赞 👍 收藏 ⭐不迷路🙉

📢:内容若有错误,敬请留言 📝指正!原创文,转载请注明出处

文章目录


前言

一开始接触状态机这一名词还不太理解,看了网上的介绍有点模棱两可、众说纷纭的感觉,其实对于程序员来说,状态机无非就是代码之间逻辑关系,实际上就是UML中的状态机图,它有开始状态,也有结束的状态,放几张示例图:



活动图:

PlantUML简介

PlantUML是一个开源工具,允许用户使用纯文本描述来创建UML(统一建模语言)图形。这种基于文本的图形描述方法具有许多优点。首先,它可以直接与源代码一起存储在版本控制系统中,从而使得代码和图形的同步变得更加简单。其次,PlantUML可以支持多种输出格式,包括PNG、SVG和LaTeX,满足了不同的需求。此外,由于其文本基础的特性,PlantUML还可以与各种工具进行集成,如Wikis、论坛、文档生成工具等。

一、如何绘制状态机?

1、安装插件plantuml和JAVA。

首先,在vscode的扩展商城中输入Plantuml, 点击进行安装。

并且需要注意如果你的电脑上没有安装java需要进行安装。

为什么需要java?因为 PlantUML 是用 java 写的,执行PlantUML 的代码需要 java。java 的安装方法本文就不再阐述了。

2、编写伪编程语言

在Plantuml中我们使用伪编程语言来生成图表。代码的文件的扩展名可以如一下:*.wsd, *.pu, *.puml, *.plantuml, *.iuml
基本格式

bash 复制代码
@startumla 
伪代码
@enduml

示例:

bash 复制代码
@startuml

start

if (Graphviz installed?) then (yes)
  :process all\ndiagrams;
else (no)
  :process only
  __sequence__ and __activity__ diagrams;
endif

stop

@enduml

3、预览生成的图表

Alt+D 或者Option+D可预览生成的图表。其次,如果写好代码后发现VScode没有更新的话,也可以按上述快捷键进行手动更新。

二、补充

2.1 Puml 官网地址

🔎Puml 官网地址:https://plantuml.com/zh/

2.2 报错:"Error: Could not register serviceworkers: InvalidstateError: Failed to regist"

vscode加载web 视图,报错:"Error: Could not register serviceworkers: InvalidstateError: Failed to regist"
解决办法

1、关闭vscode

2、按WIN + R,输入cmd,打开终端,然后输入命令 code --no-sandbox

3、会重启vscode,就可以正常使用了。

reference

参考博客

相关推荐
Howrun7777 小时前
VSCode烦人的远程交互UI讲解
ide·vue.js·vscode
Ashley的成长之路8 小时前
2025 年最新:VSCode 中提升 React 开发效率的必备插件大全
ide·vscode·react.js·工作提效·react扩展
m0_555762909 小时前
VSCODE CLAUDE CODE
ide·vscode·编辑器
esmap13 小时前
ESMAP 智慧消防解决方案:以数字孪生技术构建全域感知消防体系,赋能消防安全管理智能化升级
人工智能·物联网·3d·编辑器·智慧城市
悟能不能悟14 小时前
如何打开2个notepad++
ide
大明者省14 小时前
激活函数选型速查表(核心规则)
编辑器
wVelpro15 小时前
如何在Pycharm 2025.3 版本实现虚拟环境“Make available to all projects”
linux·ide·pycharm
GitHubDaily15 小时前
Windows 欠了 30 年的那个原生编辑器,终于回来了。
编辑器
蓝丶曦月17 小时前
MacM系列芯片安装 最新版本Notepad--(平替Windows系统的Notepad++)详细教程
编辑器·notepad++·mac
jun_bai18 小时前
VSCode使用
ide·vscode·编辑器