从离散数学到编译原理--百姓网编程题后序(读后有感)

看完这个帖子以及代码,觉得作者的C语言功底很深,尤其是字符串处理方面的函数写得很规范,很多程序设计方面的经验得以借鉴。

作者设计了一个分析字符流,形成语法树,对语法树进行语义处理整个一个程序,代码设计的模块性很强。

整个程序的算法说实在比较简单,除了程序设计方面的借鉴主要的感悟就是对词法分析,语法分析,语义分析的理解。

词法分析(是从字符流中抽出Token的函数),语法分析(利用文法对Token构建语法树),语义分析(对语法树表达的层次结构的语义升级,相对前两个阶段灵活性较大)。

词法分析设计:定义Token类型,保存每个Token对应的字符(一般在Token是标识符的时候才有必要保存),把Token返回给语法分析器。

语法分析设计:首先要设计一个消除左递归并且无二义性的文法,有了文法就按照文法左边的标示符来设计互相递归调用的函数并在调用过程中构建适当的节点在语法树中即可。

语义分析设计:灵活性较大,重要操作对象就是语法树,遍历语法树获得想要的结果。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值