博客
关于我
编译原理_复习笔记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/

    你可能感兴趣的文章
    PHP7+MySQL5.7+Nginx1.9. on Ubuntu 14.0
    查看>>
    php7.1.6 + redis
    查看>>
    php7中使用php_memcache扩展
    查看>>
    PHP7中十个需要避免的坑
    查看>>
    php7和PHP5对比的新特性和性能优化
    查看>>
    PHP7安装pdo_mysql扩展
    查看>>
    PHP7实战开发简单CMS内容管理系统(7) 后台登录架构 用户登录校验
    查看>>
    php7,从phpExcel升级到PhpSpreadsheet
    查看>>
    PHP8.1 + ThinkPHP实战指南:高效构建现代化网站的六大技巧
    查看>>
    PHP8中match新语句的操作方法
    查看>>
    PHP:第一章——PHP中常量和预定义常量
    查看>>
    PHP:第一章——PHP中的位运算
    查看>>
    phpcms
    查看>>
    phpcms 2008 product.php pagesize参数代码注射漏洞
    查看>>
    phpcms V9 自定义添加 全局变量{DIY_PATH}方法
    查看>>
    Redis五种核心数据结构的基本使用与应用场景
    查看>>
    Redis五种数据结构简介
    查看>>
    PHPCMS多文件上传和上传数量限制
    查看>>
    phpEnv的PHP集成环境
    查看>>
    PHPExcel一些基本设置总结
    查看>>