编译原理面试题

编译原理面试题

1、什么是语法分析?

识别由词法分析给出的单词符号串是否是给定文法的正确句子(程序)

2、什么是自顶向下分析法?

  • 面向目标的分析方法
  • 也就是从文法的开始符号企图推导出与输入的单词符号串完全相匹配的句子,若是输入串是给定文法的句子,则必能推导出,反之则必然出错。

3、在自顶向下的分析过程中,存在的问题是什么?

需对文法有一定限制

4、什么是确定的自顶向下分析法?

  • 定义: 确定的自顶向下分析方法,是从文法的开始符号出发,考虑如何根据当前的输入符号 (单词符号)唯一地确定选用哪个产生式替换相应非终结符以往下推导,或如何构造一棵相 应的语法树。
  • 特点:实现方法简单、直观,便于手工构造或自动生成语法分析器,是最常用的语法分析方法之一
  • 区别:自顶向下的不确定分析方法是带回溯的分析方法

5、存在的问题

当一个非终结符号对应若干个规则时,选择哪个规则的右部对该非终结符号进行展开呢?

例如:如果要被代换的最左非终结符号是U,且有n条规则:U::=A1|A2|…|An,那么如何确定用哪个规则的右部去替代U?

6、gcc hello.c 这行命令具体的执行过程,内部究竟做了什么?

7、程序一定会从main函数开始运行吗?

8、如何确定某个函数有被编译输出?

9、动态链接库和静态链接库的区别是什么?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程ID

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值