编译原理(龙书)-- 引论笔记

编译原理(龙书)-- 引论笔记

语言处理机

  • 编译器

    • 编译器是一个程序,可以阅读某一种语言(源代码),并将之翻译成另一种等价的语言(目标语言)编写的程序
    • 源程序 \Longrightarrow 编译器 \Longrightarrow 目标程序
  • 解释器

    • 解释器直接利用用户提供的输入执行源程序中指定的操作(并不通过翻译的方式生成目标程序)
  • 优缺点

    • 编译器产生的机器语言目标程序通常比一个解释器快很多
    • 解释器的错误诊断效果通常比编译器更好,因为它逐个语句执行源程序
  • Java语言处理器

    • 结合了编译解释过程
    • 源程序 \Longrightarrow 编译器 \Longrightarrow 中间程序(字节码)+ 输入 \Longrightarrow 虚拟机 (解释执行)\Longrightarrow 输出
    • Java的即时编译器:将字节码翻译成机器语言,再执行程序(跳过解释执行过程)
  • 语言处理系统

    • 源程序 \Longrightarrow 预处理器 \Longrightarrow 经过预处理的源程序 \Longrightarrow 编译器 \Longrightarrow 目标汇编程序 \Longrightarrow 汇编器 \Longrightarrow 可重定位机器代码 + 库文件、可重定位对象文件 \Longrightarrow 链接器/加载器 \Longrightarrow 目标机器代码
    • 预处理器
      • 将分割成多个文件的源程序聚合成一个独立的文件
      • 宏转换为源语言语句
    • 链接器
      • 大型程序通常需要分成多个部分进行编译,可重定向的机器代码有必要需要和其他可重定向对象文件以及库文件链接到一起,形成真正在机器上运行的代码
      • 解决:一个文件中的代码指向另一个文件中的位置,链接器解决外部内存地址问题
    • 加载器
      • 将所有的可执行目标文件放到内存中执行

编译器的结构

  • 组成
    • 前端:分析部分,检查语法语义、生成符号表和中间表示
    • 后端:综合部分,根据符号表和中间表示中的信息构建目标程序
  • 编译步骤
    • 字符流 \Longrightarrow 词法分析器 \Longrightarrow 符号流 \Longrightarrow 语法分析 \Longrightarrow 语法树 \Longrightarrow 语义分析 \Longrightarrow 语法树 \Longrightarrow 中间代码生成器 \Longrightarrow 中间表示形式 \Longrightarrow 机器无关代码优化器 \Longrightarrow 中间表示形式 \Longrightarrow 代码生成器 \Longrightarrow 目标机器语言 \Longrightarrow 机器相关代码优化器 \Longrightarrow 目标机器语言
  • 词法分析(扫描)
    • 读入源程序字符流,将它们组织成有意义的词素(lexeme)序列
    • <token-name(抽象符号),attribute-value(指向符号表中关于这个词法单元的条目)>
    • 例如:
      • position = initial + rate * 60
      • <id,1><=><id,2><+><id,3><*><60>
  • 语法分析
    • 使用由词法分析器生成的各个词法单元的第一个分量来创建树型的中间表示
    • 常用的表示方法:语法树(树中的每个内结点表示运算,子节点表示该运算的分量)
  • 语义分析
    • 使用语法树符号表中的信息来检查源程序是否和语言定义的语义一致
    • 收集类型信息,并把这些信息存放在语法树或符号表中
    • 类型检查
  • 中间代码生成
  • 代码优化
  • 代码生成
  • 符号表管理
    • 记录源程序中使用的变量的名字,并收集和每个名字的各种属性有关的信息
    • 这些属性可以提供一个名字的存储分配、它的类型、作用域等信息
    • 符号表数据结构为每个变量名字创建了一个记录条目
  • 将多个步骤组合成趟
    • 在特定的实现中,多个步骤可以组合成一趟(pass)
  • 编译器构造工具
    • 常用编译器构造工具
      • 语法分析器的生成器
      • 扫描器的生成器
      • 语法制导的翻译引擎
      • 代码生成器的生成器
      • 数据流分析引擎
      • 编译器构造工具集

程序设计语言

  • 按代分类
    • 机器语言(第一代)
    • 汇编语言(第二代)
    • 高级程序设计语言(第三代)
    • 为特定应用设计的语言(第四代,例如SQL)
    • 基于逻辑和约束的语言(第五代,例如Prolog、OPS5)
  • 按计算任务的完成方式分类
    • 强制式:程序中指明如何完成一个计算任务
      • 例如:C、C++、C#、Java
    • 声明式:程序中指明进行哪些计算
      • 例如:ML、Haskell、Prolog
  • 冯·诺依曼语言:指以冯·诺依曼计算机体系结构为计算模型的程序语言
  • 面向对象语言:指用一组相互作用的对象组成程序的变成风格
  • 脚本语言:具有高层次运算符的解释型语言,通常被用于把多个计算过程“粘合”在一起
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335