博客
关于我
编译原理_复习笔记1-2章
阅读量:74 次
发布时间:2019-02-26

本文共 967 字,大约阅读时间需要 3 分钟。

引论与语法描述介绍

编译程序的主要任务是将一种高级语言程序转换为低级语言程序(如汇编或机器码)。在描述语言的词法和语法规则时,正规式(Regular Expression)和有限自动机(Finite Automaton)是非常有效的工具。

关键概念解析

  • 标识符与名字:标识符是语义概念,而名字是语法概念。
  • 词法与语法
    • 词法规则主要定义语言中的基本元素,如常数、标识符、算符等,通常用有限自动机来描述。
    • 语法规则定义语言的结构,涵盖表达式、语句、分程序等,通常用上下文无关文法来描述。

语法推导

  • 最左推导:在任何推导步骤中,首先替换最左边的非终结符。
  • 最右推导(规范推导):在任何推导步骤中,首先替换最右边的非终结符,所得句型称为规范句型。

文法分类

语言的文法可以分为以下几种类型:

  • 0型文法(最宽泛):产生式形如 α → ß,其中 α 是由终结符和非终结符组成的任意长度的串,且至少包含一个非终结符。
  • 1型文法(上下文无关文法):产生式形如 α → ß,且 α 的长度不超过 ß 的长度(仅 S → ℇ 例外)。
  • 2型文法(非确定下推自动机):产生式形如 A → ß,其中 A 是非终结符,ß 是终结符和非终结符的任意长度的串。
  • 3型文法(有限自动机):产生式形如 A → αB、A → Bα 或 A → α,其中 α 是一个单一的终结符或非终结符。
  • 文法应用

    • 2型文法:常用于语法分析,编译器在解析源程序时通常使用非确定性下推自动机。
    • 3型文法:常用于词法分析,其限制更为严格,适用于需要更强类型检查的语言。

    语言与句型

    • 句型:由文法产生的由终结符和非终结符组成的序列。
    • 句子:仅由终结符组成的句型。
    • 语言:由文法产生的所有句子的集合。

    关键概念

    • :从头到尾扫描源文本。
    • 开始符:非终结符,通常用大写字母表示。
    • 终结符:无法再进行推导的符号。
    • 文法推导:从句型推导到句子,因为句子只能由终结符组成。

    闭包与推导树

    • *V^ 和 V^+**:V 的闭包和正规闭包。
    • 语法树:描述句型推导的图形。
    • 语言的二义性:如果无二义性文法无法描述该语言,则该语言为二义语言。

    本文旨在提供语言结构的基础知识,帮助理解编译原理中的关键概念。编译器开发者在实际工作中通常会专注于2型和3型文法的实现,这两种文法类型在语法分析和词法分析中各有优势。

    转载地址:http://rhck.baihongyu.com/

    你可能感兴趣的文章
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS共享文件系统搭建
    查看>>
    nfs复习
    查看>>
    NFS网络文件系统
    查看>>