您好,欢迎光临有路网!
编译原理和技术
QQ咨询:
有路璐璐:

编译原理和技术

  • 作者:丁文魁 杜淑敏
  • 出版社:电子工业出版社
  • ISBN:9787121060601
  • 出版日期:2008年03月01日
  • 页数:304
  • 定价:¥31.00
  • 分享领佣金
    手机购买
    城市
    店铺名称
    店主联系方式
    店铺售价
    库存
    店铺得分/总交易量
    发布时间
    操作

    新书比价

    网站名称
    书名
    售价
    优惠
    操作

    图书详情

    内容提要
    编译原理和技术是计算机专业的基础课程,本书系统介绍了与编译相关的知识。全书共分9章,第1章的编译概述讨论了编译程序的各个组成部分:第2章介绍有关形式语言的一些基本概念;第3章介绍词法分析,它是整个分析过程的一个子任务;第4章详细讨论了用于编译程序构造中的一些典型的语法分析方法;第5章引入了语法制导定义和翻译模式这两个概念,并给出了如何书写L-属性的翻译模式的方法;第6章讨论用来支持一个程序的运行时刻环境的有关存储组织的各种问题;第7章讨论的是中间代码生成;第8章介绍目标代码生成;第9章集中讨论中间代码优化。
    为方便教师讲解和学生实验,本书配有光盘。
    本书适合作为计算机专业编译原理课程的教材,也可作为广大工程技术人员的参考资料。
    文章节选
    第1章 编译概述
    编译是指将一个用源语言书写的程序转换成一个等价的用目标语���书写的程序。一般而言,源语言是面向人的,而目标语言是面向计算机的。
    1.1 翻译和解释
    世界上存在着多种语言,人们为了通信方便,就需要建立各种语言之间的翻译。人与计算机之间的信秘交流,同样存在一个翻译问题。每种计算机都有自己独特的指令系统,亦即这种机器的机器语言。
    ……
    目录
    第1章 编译概述
    1.1 翻译和解释
    1.2 编译程序的组成部分
    1.2.1 分析
    1.2.2 综合
    1.2.3 表格管理
    1.2.4 错误处理
    1.3 编译程序的组织
    第2章 程序语言的基本知识
    2.1 符号串的集合
    2.1.1 字母表
    2.1.2 符号串
    2.1.3 语言
    2.2 文法和语言
    2.2.1 引言
    2.2.2 文法和语言的形式定义
    2.3 分析树和二义性
    2.3.1 分析树
    2.3.2 分析树的构造
    2.3.3 二义性
    2.4 形式语言概观
    2.4.1 形式语言分类
    2.4.2 非上下文无关的语言结构
    2.4.3 上下文无关语言和正则语言的区别
    练习
    第3章 词法分析
    3.1 词法分析程序的设计
    3.1.1 词法分析程序的功能
    3.1.2 单词的词类和属性
    3.1.3 词法分析程序作为一个独立子程序
    3.2 词法分析程序的手工构造
    3.2.1 确定的有限自动机
    3.2.2 构造识别单词的:DFA
    3.2.3 编写词法分析程序
    3.3 有限自动机
    3.3.1 非确定有限自动机
    3.3.2 确定的有限自动机的化简
    3.4 正规表达式与有限自动机
    3.4.1 正规表达式与单词
    3.4.2 正规表达式与有限自动机的等价性
    3.5 词法分析程序的自动构造工具
    练习
    第4章 语法分析
    4.1 语法分析器概述
    4.2 预测分析器
    4.2.1 预测分析
    4.2.2 递归预测分析器的构造
    4.2.3 非递归的预测分析器的构造
    4.3 书写文法
    4.3.1 消除左递归
    4.3.2 提取左因子
    4.4 自底向上分析
    4.4.1 规范归约
    4.4.2 “移进一归约”分析法的栈实现
    4.5 算符优先分析法
    4.5.1 利用算符优先关系寻找右句型的可归约串
    4.5.2 算符优先关系表的构造
    4.5.3 优先函数
    4.5.4 算符优先分析法的错误处理示例
    4.6 LR分析器
    4.6.1 LR分析器的逻辑结构及工作过程
    4.6.2 SLR分析表的构造
    4.6.3 LR(1)分析表的构造
    4.6.4 LALR分析表的构造
    4.7 LR分析方法对二义文法的应用
    4.8 分析器的生成器Yacc
    4.8.1 引言
    4.8.2 书写Yacc的源程序
    4.8.3 用Yacc处理二义文法
    4.8.4 用Lex建立Yacc的词法分析器
    4.8.5 Yacc的错误恢复
    练习
    第5章 语法制导翻译
    5.1 语法制导定义
    5.1.1 语法制导定义的形式
    5.1.2 综合属性
    5.1.3 继承属性
    5.1.4 依赖图
    5.1.5 计算顺序
    5.2 语法树的构造
    5.2.1 语法树
    5.2.2 建立表达式的语法树
    5.2.3 建立语法树的语法制导定义
    5.2.4 关于表达式的有向非循环图
    5.3 S-属性定义及其自底向上的计算
    5.4 L-属性定义
    5.4.1 L-属性定义的含义
    5.4.2 翻译模式
    5.5 自顶向下的翻译
    5.5.1 从翻译模式中消除左递归
    5.5.2 预测翻译器的设计
    5.6 自底向上计算继承属性
    5.6.1 从翻译模式中去掉嵌入的动作
    5.6.2 分析栈中的继承属性
    5.6.3 模拟继承属性的计算
    练习
    第6章 运行时刻环境的组织
    6.1 有关源语言中的一些问题的讨论
    6.1.1 过程
    6.1.2 活动树
    6.1.3 控制栈
    6.1.4 说明的作用域
    6.1.5 名字的绑定
    6.1.6 提出的问题
    6.2 存储组织
    6.2.1 运行时刻内存的划分
    6.2.2 活动记录
    6.2.3 编译时刻的局部数据的设计
    6.3 运行时刻存储分配策略
    6.3.1 静态存储分配
    6.3.2 栈式存储分配
    6.3.3 堆式存储分配
    6.4 对非局部名字的访问
    6.4.1 块
    6.4.2 不含嵌套过程的词法作用域
    6.4.3 含有嵌套过程的词法作用域
    6.4.4 动态作用域
    6.5 参数传递
    6.5.1 传值调用
    6.5.2 引用调用
    6.5.3 复制恢复
    6.5.4 传名调用
    6.5.5 过程作为参数
    6.6 符号表
    6.6.1 符号表的作用
    6.6.2 符号表的表项
    6.6.3 符号表的存储结构
    练习
    第7章 中间代码生成
    7.1 中间语言
    7.1.1 图表示法
    7.1.2 三地址代码
    7.1.3 三地址语句的种类
    7.1.4 语法制导翻译生成三地址代码
    7.1.5 三地址代码的具体实现
    7.2 类型检查
    7.2.1 类型表达式
    7.2.2 类型表达式的等价
    7.2.3 类型检查
    7.2.4 类型转换
    7.3 说明语句
    7.3.1 过程中的说明语句
    7.3.2 保留作用域信息
    7.3.3 记录中的域名
    7.4 赋值语句
    7.4.1 符号表中的名字
    7.4.2 数组元素地址分配
    7.4.3 访问数组元素的翻译模式
    7.4.4 访问记录中的域
    7.5 布尔表达式和控制流语句
    7.5.1 翻译布尔表达式的方法
    7.5.2 数值表示法
    7.5.3 控制流语句
    7.5.4 控制流语句中布尔表达式的翻译
    7.6 CASE语句
    7.7 回填
    7.7.1 使用回填翻译布尔表达式
    7.7.2 使用回填翻译控制流语句
    7.7.3 标号和转移语句
    7.8 过程调用
    练习
    第8章 代码生成
    8.1 目标机器
    8.2 运行存储管理
    8.2.1 静态分配管理
    8.2.2 栈式分配管理
    8.2.3 名字的运行地址
    8.3 基本块和流图
    8.3.1 基本块
    8.3.2 流图
    8.4 下次引用信息
    8.5 一个简单的代码生成器
    8.5.1 寄存器描述器和地址描述器
    8.5.2 代码生成算法
    8.6 基本块的dag表示法
    8.6.1 dag的构造
    8.6.2 dag的应用
    8.7 从dag生成目标代码
    练习
    第9章 中间代码的优化
    9.1 引言
    9.1.1 代码优化的标准
    9.1.2 争取较好的性能
    9.1.3 优化编译器的组织
    9.2 优化的主要种类
    9.2.1 公共子表达式
    9.2.2 复写传播
    9.2.3 死代码删除
    9.2.4 循环优化
    9.3 流图中的循环
    9.3.1 必经结点
    9.3.2 自然循环
    9.3.3 内循环
    9.3.4 前置结点
    9.3.5 归约流图
    9.4 全局数据流分析介绍
    9.4.1 点和路径
    9.4.2 到达一定值
    9.4.3 集合的表示
    9.4.4 局部的到达一定值
    9.4.5 引用一定值链
    9.5 数据流方程的迭代求解
    9.5.1 到达一定值的迭代算法
    9.5.2 可用表达式
    9.5.3 活跃变量分析
    9.5.4 定值一引用链
    9.5.5 流图结点的深度优先次序
    9.5.6 用深度优先次序改进数据流求解算法
    9.6 优化的实现
    9.6.1 删除公共子表达式
    9.6.2 复写传播
    9.6.3 寻找循环不变计算
    9.6.4 代码外提
    9.6.5 代码外提后维持数据流信息
    9.6.6 归纳变量
    9.6.7 有循环不变计算的归纳变量
    练习
    参考文献
    编辑推荐语
    本书共分9章。第1章的编译概述讨论了编译程序的各个组成部分,从中读者可以了解到编译程序构造的各主要方面。第2章介绍有关形式语言的一些基本概念,这些是学习本书必要的基础知识。第3章介绍词法分析,它是整个分析过程的一个子任务。设计词法分析程序的理论基础是有限自动机。文中详细讨论了正规表达式和有限自动机的等价转换算法。第4章详细讨论了用于编译程序构造中的一些典型的语法分析方法。第5章的语法制导翻译中,为使文法的产生式和语义规则联系起来,引进了语法制导定义和翻译模式这两个概念,并给出如何书写L-属性的翻译模式的方法。第6章讨论用来支持一个程序的运行时刻环境的有关存储组织的各种问题。之后,在第7章利用语法制导定义和翻译模式这两个概念来讨论中间代码生成。第8章在上一章的基础上介绍目标代码生成。*后,第9章集中讨论中间代码优化,比较详细地阐述了数据流分析和主要的全局优化方法。
    本套教材在**规划教材的基础上,进行全面更新,以适应高校课程与教学改革的需要,并特别注意教材的可读性和可用性,为任课教师提供各种教学服务。

    与描述相符

    100

    北京 天津 河北 山西 内蒙古 辽宁 吉林 黑龙江 上海 江苏 浙江 安徽 福建 江西 山东 河南 湖北 湖南 广东 广西 海南 重庆 四川 贵州 云南 西藏 陕西 甘肃 青海 宁夏 新疆 台湾 香港 澳门 海外