markdown mermaid状态图
状态图
状态图是一种用于计算机科学和相关领域描述系统行为的图。状态图要求描述的系统由有限数量的状态组成。
语法:
stateDiagram-v2
[*] --> Still
Still --> [*]
Still --> Moving:push
Moving --> Still:摩擦
Moving --> Crash:速度过快
Crash --> [*]
[*] --> Still
Still --> [*]
Still --> Moving:push
Moving --> Still:摩擦
Moving --> Crash:速度过快
Crash --> [*]
在状态图中,展示了系统有那些状态,以及状态之间相互转换的。 上面的示例图显示了 Still、Moving
和 Crash
三种状态。 可以将Still
状态 更改为 Moving
。 也可以将Moving
状态更改回Still
或Crash
。 但无法从Still
过度到Crash
状态。
- 状态
可以通过多种方式声明一个状态。 最简单的方法是状态定义是通过 id 。
stateDiagram-v2
id
id
定义状态的另一种方法是,状态id后接冒号和描述。
stateDiagram-v2
S:开始
R:运行
W:等待
S-->R:start()
R-->W:wait()
W-->R:notify(),nofityAll()
S:开始
R:运行
W:等待
S-->R:start()
R-->W:wait()
W-->R:notify(),nofityAll()
id:des :状态id:状态详细
如果状态比较长,并且要多次引用,可以用此种方式,可以减少敲打键盘的的次数。
- 过渡:状态转换
当一种状态进入另一种状态时,通过过渡转换。 这使用文本箭头-->
表示。
stateDiagram-v2
状态1 --> 状态2
状态1 --> 状态2
可以向过渡中添加文本。描述它代表什么。
stateDiagram-v2
new-->Runable:start()
new-->Runable:start()
- 开始和结束
有两种特殊状态指示图,开始和停止。 可以用 [*]
语法表示开始或停止状态。
stateDiagram-v2
[*] --> 运行
s1 --> [*]
s1:运行
[*] --> s1
s1 --> [*]
例子:
Java线程状态图:
stateDiagram-v2
New-->Runnable:start()
Runnable-->Waiting:wait()
Waiting-->Runnable:notify(),notifyAll()
TimedWaiting-->Runnable:sleep()结束
Runnable-->TimedWaiting:sleep()开始
Blocked-->Runnable:synchronized
Runnable-->Blocked:synchronized
Runnable-->Terminated:run()结束
New-->Runnable:start()
Runnable-->Waiting:wait()
Waiting-->Runnable:notify(),notifyAll()
TimedWaiting-->Runnable:sleep()结束
Runnable-->TimedWaiting:sleep()开始
Blocked-->Runnable:synchronized
Runnable-->Blocked:synchronized
Runnable-->Terminated:run()结束
markdown mermaid状态图的更多相关文章
- Markdown Mermaid
Mermaid 是一个用于画流程图.状态图.时序图.甘特图的库,使用 JS 进行本地渲染,广泛集成于许多 Markdown 编辑器中. 之前用过 PlantUML,但是发现这个东西的实现原理是生成 U ...
- markdown mermaid序列图
序列图(时序图) 序列图是一种交互图,它显示了进程如何相互操作以及按什么顺序操作. sequenceDiagram participant l as 大灰狼 participant y as 小羊 l ...
- markdown mermaid流程图
流程图 所有流程图都由节点.几何图像.箭头或线条组成. mermaid代码定义了这些节点和边的制作和交互方式.可以有不同的箭头类型.多向箭头以及与子图的连接. 节点 节点 flowchart LR i ...
- 我画着图,FluentAPI 她自己就生成了
在 Newbe.ObjectVistor 0.3 版本中我们非常兴奋的引入了一个紧张刺激的新特性:使用状态图来生成任意给定的 FluentAPI 设计. 开篇摘要 在非常多优秀的框架中都存在一部分 F ...
- Markdown中使用mermaid画流程图
Markown语法简单,用来写文档是个不错的选择. 但是Markdown 语法并不直接支持画图,当然方法还是有的. 本人用的Markdown编辑器为vscode,在里面直接安装merdaid插件即可使 ...
- markdown绘图插件----mermaid简介
作者:黄永刚 mermaid简介 当撰写文档的时候,对于流程图的生成大多使用Visio等繁重的工具,没有一种轻便的工具能够画图从而简化文档的编写,就像markdown那样. mermaid解决这个痛点 ...
- Markdown教程<2> mermaid图形绘制(1)
Markdown教程<2> mermaid图形绘制(1) 博客园中的markdown编辑器同时支持mermaid图表引擎与tex公式引擎,可以使用mermaid直接画出流程图,时序图,甘特 ...
- 画图前端:mermaid。时序图/类图/甘特图/流程图/状态图/饼图。类似工具:Typora
文档 https://mermaidjs.github.io/#/ cdn https://www.bootcdn.cn/mermaid/ 在线编辑 https://mermaidjs.github. ...
- Markdown画图(mermaid)学习
简介 目前博客园支持mermaid的graph,subgraph,sequenceDiagram,gantt,classDiagram mermaid(美人鱼), 是一个类似markdown,用文本语 ...
随机推荐
- CF507A Amr and Music 题解
Content 有一个容量为 \(k\) 的背包.有 \(n\) 个物品,第 \(i\) 个物品的体积为 \(c_i\).请求出背包最多能够装下的物品的个数,并输出任意一个方案. 数据范围:\(1\l ...
- 使用Nginx配置资源目录展示下载
nginx配置文件 server { listen 8080; server_name localhost; charset utf-8; location /download { #下载的资源目录 ...
- mac osx 准备 nanogui 记录
!!版权声明:本文为博主原创文章,版权归原文作者和博客园共有,谢绝任何形式的 转载!! 作者:mohist mac osx : 10.14.6 Mojave. 之前没有配置openGL相关开发环境,自 ...
- 【LeetCode】794. Valid Tic-Tac-Toe State 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址: https://leetcode.com/problems/valid-ti ...
- 【剑指Offer】扑克牌顺子 解题报告(Python)
[剑指Offer]扑克牌顺子 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-interviews 题目描 ...
- Sum Of Gcd(hdu 4676)
Sum Of Gcd Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- BP网络简单实现
目录 BP算法的简单实现 Linear 全连接层 ReLu MSELoss 交叉熵损失函数 BP算法的简单实现 """ BPnet 简易实现 约定输入数据维度为(N, i ...
- [C++]vector去除重复元素
#include <iostream> #include <vector> #include <algorithm> #include <set> us ...
- C语言string操作
创建方式 字符数组:空间已定 字符指针:未分配空间 初始化 字符数组: 创建与赋值必须在同一行 指定大小:未填满部分用'\0'填充 用字符串初始化:末尾自动添加'\0' 不初始化赋值则乱值 字符指针: ...
- ARTS Week 19
Algorithm 本周的 LeetCode 题目为 5. 最长回文子串 给你一个字符串 s,找到 s 中最长的回文子串.例如输入:s = "babad",输出:"bab ...