![编译系统透视:图解编译原理](https://wfqqreader-1252317822.image.myqcloud.com/cover/487/844487/b_844487.jpg)
上QQ阅读APP看书,第一时间看更新
2.3 状态转换图
2.3.1 状态转换图总体介绍
词法分析的过程是根据C语言的词法规则进行的,为了指导词法分析器的程序设计,需要形式化地表达C语言的词法规则。下面我们用状态转换图的形式来展现这个案例程序能用到的词法规则,如图2-19所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0061.jpg?sign=1738951527-1zSQs9SiDjXLtxZo2RYIv40QPNuhhtlP-0-2d1d9f10cd20de7a8b8c039ccb172e80)
图2-19 前面介绍内容所涉及的状态转换图
图2-19是一个完整的转换图,我们来看词法分析的每个步骤在转换图上对应的状态。
首先是起始状态,即我们前面所介绍的计算机准备识别下一个符号的状态,如图2-20所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0062.jpg?sign=1738951527-0AYpMIXFEZJTQvGyGccGtwxWxEJSTV2J-0-a83708329dce60d50af0f67aa48e8410)
图2-20 状态转换图处于起始状态
我们以标识符符号的识别为例,只要识别到字母、数字或下划线,就进入标识符识别状态,情景如图2-21所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0063.jpg?sign=1738951527-vHL15VAp8LiorTaa5EOuQRRvXDYAdKIP-0-c7bba5de4436074173e53e272f566bdc)
图2-21 识别到字母或下划线的状态
之后,只要遇到字母、数字或下划线,就仍然在这个状态中进行识别,情景如图2-22所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0064.jpg?sign=1738951527-47HkaAwofqQmXQvrZHSmIrRtYegCI15p-0-828937c3b66a4fe0918658ddc786d2fb)
图2-22 不断识别到字母、数字或下划线的状态
直到条件不再符合,就进入终态,表示此标识符已经识别完毕,情景如图2-23所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0065.jpg?sign=1738951527-nza7txD5QEIjTt7AN9j8fcqSMDmGw5RQ-0-ed98dff779c51abad04d555f876b7555)
图2-23 进入终态并确定符号为标识符
然后从起始状态开始准备识别下一个符号,情景如图2-24所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0066.jpg?sign=1738951527-3RlH5RJrMpmat5ExDZCcuihCZ98MGQZy-0-60b0764a240358e88f980715b039239b)
图2-24 重新回到起始状态
下一个字符可能是数字、分隔符或运算符。如果是数字,情景如图2-25所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0067.jpg?sign=1738951527-3X8WMDsvlvZRWd84pIdDXmWZ6tFj8z3R-0-1531c43f621e4173fbf799a23f99f2e1)
图2-25 识别到数字的状态
如果是分隔符,情景如图2-26所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0068.jpg?sign=1738951527-iV2LdjuQJI9FJv67XSpfjM8FI9vc3UQi-0-8a79e66fd0def5326417a89853f63a1b)
图2-26 识别到“,”的状态
如果是运算符,情景如图2-27所示。
![](https://epubservercos.yuewen.com/CCC398/5922738704546701/epubprivate/OEBPS/Images/figure_0069.jpg?sign=1738951527-4Zu4avAY47YK46Q60GTtoVMAi7MTaA3l-0-cfaa49d7d655cb7ab898be69bb8bc11b)
图2-27 识别到“=”的状态