Lex识别C风格字符串和注释

本文探讨了如何使用Lex识别C语言中的字符串和注释。在字符串识别中,详细阐述了处理转义引号和限制转义符正确配对的方法。对于注释的识别,介绍了处理单行和多行注释的正则表达式策略,并提到了在实际的Lex应用中,可以通过C代码直接处理注释丢弃的简化方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Welcome

Lex和Yacc是Unix下不错的词法分析器和语法分析器,在linux下,这两个工具被成为flex和bison,也是C++经常用来构建字符分析程序的工具。

本文不是一篇入门文章,我们假设您已经了解了Lex和Yacc的基本语法
入门文章请参考IBM的:【Yacc 与 Lex 快速入门】

我们这里讨论一些其有趣的用法和注意的事项

字符串的识别

常规的正则式和匹配问题都难不倒大家,那么下面来想一个问题,C语言中字符串如何识别?

我们知道,字符串一般是这样的

"some \"string\" problem.\n"

但我们会发现其中包含有转移符和引号,如何只是简单的如下书写正则式:

\"[^"]*\"

则会导致引号表达能力不全,不能满足C语言的要求。

所以我们考虑将里面的表达部分拆开,

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值