【编译原理】第二章 一个简单的语法制导翻译器

2024-04-05 01:58

本文主要是介绍【编译原理】第二章 一个简单的语法制导翻译器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,语法定义

        1)文法:对语言结构的定义与描述。即从形式上用于描述和规定语言结构的称为“文法”(或称为“语法”),而未
涉及语义问题。

                                  例:有一句子:“我是大学生” 。这是一个在语法、语义上都正确的句子,该句子的结构(称为语法结构)是由它的语法决定的。在本例中它为“主谓结构”

       2)文法定义

                文法G=(Vn,Vt,P,Z)
                        Vn:非终结符号集,语法变量
                         Vt:终结符号集,词法单元
                          P:产生式或规则的集合
                           Z:开始符号(识别符号) Z∈Vn

           例:if(expression)   statement  else  statement;   

                   关键字if 和括号:为 终结符号(词法单元)

                  expression、statement:非终结符号

      3)推导

           从一个要识别的符号开始推导,即用相应规则的右部来替代规则的左部,每次仅用一条规则去进行推导。从开始符号出发,不断将某个非终结符号替换为该非终结符号的某个产生式的体。

        <句子>::=<主语><谓语>
        <主语>::=<代词>|<名词>
        <代词> ::=你|我|他
        <名词>::= 王民|大学生|工人|英语
        <谓语>::=<动词><直接宾语>
        <动词>::=是|学习
        <直接宾语>::=<代词>|<名词>

     4)语法分析

           接受一个终结符号串作为输入,找出从文法的开始符号推导出这个串的方法。如果不能从文法符号推到得到该终结符号串,则报错。

     5)语法分析树

           语法分析树被定义为具有下述性质的一棵树:
             1) 根由开始符号所标记;
             2) 每个叶子由一个终结符、非终结符、或ε标记;
             3) 每个内部结点由一个非终结符标记;
             4) 若A是某内部节点的标记,且X1,X2,...,Xn是该节点从左到右所有孩子的标记,则A→X1X2...Xn是一个产生式。若A→ε,则标记为A的结点可以仅有一个标记为ε的孩子。 

     

     例子:9-5+2

             文法的产生式:list -> list + digit ;  

                                        list -> list - digit ; 

                                        list -> digit

                                        digit -> 0 | 1| 2| 3| 4| 5| 6| 7| 8|  9

                       非终结符:list  digit  list是文法开始符号

                       终结符:零个或多个终结符号组成的序列,零个终结符组成的串称为空串

            语法分析树:

                                                       list

                                                  /     |      \

                                            list        |         digit

                                       /     |    \     |            |

                                      list   |   digit |            |

                                       |     |     |    |            |

                                      9     -     5   +          2

          6)二义性

               一个文法可能有多颗语法分析树,生成同一个给定的终结符号。

           例子:句子id+id*id可能的分析树  


                     (id+id)*id    id+id*id    

           消除二义性:

                     ① 改写二义文法为非二义文法;
                     ② 规定二义文法中符号的优先级和结合性,使仅产生一棵分析树。

          二义文法的优点:
                     ①  比非二义文法容易理解;
                     ②  分析效率高(分析树低,直接推导步骤少)。

三,语法制导翻译

        1)属性:与某个程序构造相关的任意的量,属性可以使多种多样的,比如表达式的数据类型、生成的代码中的指令数目或为某个生成的代码中第一条指令的位置。

        2)翻译方案:将程序片段附加到一个文法的各个产生式上的表示法。当在语法分析过程中使用一个产生式时,相应的程序片段就会执行。

        3)语法制导定义:把每个文法符号和一个属性集合相关联,并且把 ② 每个产生式和一组语义规则相关联,这些规则用于计算与该产生式中符号相关联的属性值


四,语法分析

       1)语法分析:决定如何使用一个文法生成一个终结符号串的过程。原则上语法分析器必须能够构造出语法分析树,否则将无法保证翻译的正确性

       2)语法分析分为:自顶向下分析方法和自底向上分析方法

       3)自顶向下分析方法:构造方法从根节点开始,逐步向叶子节点方向进行。

       4)预测分析法(递归下降分析法):自顶向下的语法分析方法,使用一组递归过程来处理输入。


五,简单表达式的翻译器

        1)抽象语法树:每个内部节点代表一个运算符(而不像语法分析树 为非终结符号)

        2)将中缀表达式翻译成后缀表达式:

package demo_parser;
import java.io.*;public class Demo_Parser {static int lookahead;//字节流以整数形式(ascii码中对应十进制数)表示public Demo_Parser() throws IOException{lookahead=System.in.read();//read方法以字节流的方式来读取命令行的输入的数据}void term() throws  IOException  //如果是数字则输出(不识别字母){if(Character.isDigit((char)lookahead)){System.out.write((char)lookahead);match(lookahead);}else throw new Error("syntax error");}void match(int t)throws  IOException{if(lookahead == t)lookahead= System.in.read();elsethrow new Error("syntax error");} void expr() throws IOException{term();while(true){if(lookahead =='+'){match('+');term();System.out.write('+');}else if(lookahead == '-'){match('-');term();System.out.write('-');}else return;      }}public static void main(String[] args) throws IOException{Demo_Parser parser = new Demo_Parser();parser.expr();System.out.write('\n');}
}


六,词法分析

        1)从输入中读取字符,并将它们组成”词法单元对象“。构成一个词法单元的输入字符序列成为词素。

        2)剔除空白和注释:实现这个远非易事

        3)预读:比如读到 then 还要往下读,如果是空格或其他非标识符则判断为关键字。否则为标识符(thenOther) 

                <=    >=   ==  <>

        4)识别关键字和标识符:词法分析采用一个表来保存字符串


七,符号表

        1)符号表:一种供编译器用于保存有关源程序构造的各种信息的数据结构。这些信息在编译器的分析阶段被逐步手机并放入符号表。

        2)符号表条目:在分析阶段由,词法分析器、语法分析器和语义分析器创建并使用。语法分析器创建。

        3)每个作用域设置一个符号表,其作用是将信息从声明的地方传递到实际使用的地方。


八,生成中间代码

        1)两种中间表示形式:树形结构,线性表示形式(特别是"三地址代码")

       

                            











这篇关于【编译原理】第二章 一个简单的语法制导翻译器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/877373

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.