编译原理之正则表达式RE和词法分析NFA(第一篇)

一、编译器概述

1.编译器

编译器是一个程序
核心功能是把源代码个翻译成目标代码,输出一个可执行程序
源代码:C/C+++,java ,html,SQL
目标代码: xxx86,IA64,ARM,MIPS

在这里插入图片描述

2.解释器

解释器也是处理程序的一种程序,直接输出结果

3.编译结构

编译器是非常模块化的高层结构,

4.栈

栈(stack)在计算机科学中是限定仅在表尾进行插入或删除操作的线性表。栈是一种数据结构,它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据。栈是只能在某一端插入和删除的特殊线性表。用桶堆积物品,先堆进来的压在底下,随后一件一件往上堆。取走时,只能从上面一件一件取。读和取都在顶部进行,底部一般是不动的。栈就是一种类似桶堆积物品的数据结构,进行删除和插入的一端称栈顶,另一端称栈底。插入一般称为进栈,删除则称为退栈。 栈也称为后进先出表。</

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
正则表达式编译原理中广泛应用于词法分析器的模式匹配阶段。它是一种描述字符串模式的形式化语言,可以用于匹配、查找和操作文本数据。正则表达式通常由字符、字符类、重复和逻辑操作符组成,用于描述一定规则的字符串模式。 在编译原理中,正则表达式被用来定义词法单元的模式,例如标识符、关键字、运算符等。通过将正则表达式转换为等价的有限状态自动机(DFA)或非确定有限状态自动机(NFA),词法分析器可以将输入的源代码按照模式进行分割,并生成对应的词法单元流。 正则表达式的基本语法包括以下几种元字符: - 字符:表示匹配该字符本身,例如 'a' 匹配字符 'a'。 - 字符类:用方括号 [] 表示,表示匹配其中的任意一个字符,例如 '[abc]' 匹配字符 'a'、'b' 或 'c'。 - 重复:用 *、+、?、{n}、{n,}、{n,m} 等表示,表示匹配前一个元素的重复次数,例如 'a*' 匹配零个或多个 'a'。 - 逻辑操作符:包括连接符(.)、选择符(|)和分组符(()),用于组合多个表达式,例如 'ab|cd' 匹配 'ab' 或 'cd'。 除了基本语法外,正则表达式还支持一些特殊字符的转义序列,如 \d 表示任意一个数字字符,\w 表示任意一个字母数字字符等。 在编译原理中,通常会使用工具或库来解析和处理正则表达式,生成对应的词法分析器代码。常见的工具包括Flex、ANTLR等。 希望以上信息对你有所帮助!如果你还有其他问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值