词法分析阶段的错误处理

词法分析阶段可检测错误的类型:

  • 单词拼写错误:
    • 例:int i = 0x3G(16进制数表示错误)、float j = 1.05e(指数表示错误)
  • 非法字符:例如~、@等

词法错误检测:

如果当前状态与当前输入符号在转换表对应项中的信息为空意为在当前状态下不应该接受到当前接受到的字符)。则报错,并调用错误处理程序。

错误处理

  • 查找已扫描字符串中最后一个对应于某终态的字符。
    • 如果找到了,将该字符与其前面的字符识别成一个单词 。然后将输入指针退回到该字符,扫描器回到初始状态,继续识别下一单词。
    • 如果没找到,则确定出错,采用错误恢复策略。

错误恢复策略例如最简单的恐慌模式(panic mode)。即从剩余的输入中不断删除字符,直到词法分析器能够在剩余的开头发现一个正确的字符为止。

猜你喜欢

转载自blog.csdn.net/hjc256/article/details/87713960