咖水 LANZHOU UNIVERSITY 编译原理课件中 鉴州大学信息誉院 CompilerPrinciples
CompilerPrinciples 1
第一讲引论 ◆课程信息 ◆编译程序概述 ◆高级语言的语法描述
第一讲 引论 ◆课程信息 ◆编译程序概述 ◆高级语言的语法描述
§1.课程信息 、 课程名称:编译原理 ·基本内容是介绍编译程序构造的基本原理、 方法和技术,包括词法分析、语法分析、 语义分析与中间代码产生、代码优化及目 标代码产生等。简言之,就是介绍如何将 源程序翻译成目标代码程序。 CompilerPrinciples
CompilerPrinciples 3 §1.课程信息 一、课程名称:编译原理 ❖ 基本内容是介绍编译程序构造的基本原理、 方法和技术,包括词法分析、语法分析、 语义分析与中间代码产生、代码优化及目 标代码产生等。简言之,就是介绍如何将 源程序翻译成目标代码程序
二、课程性质:专业基础课,必修 编译程序(器)出现于上世纪50年代后期 (第一个高级语言1958年) ÷60年代~70年代是研究高峰期 ÷60年代中期开始在高校中开设课程 80年代开始作为计算机科学与技术专业的 必修基础课程 CompilerPrinciples
CompilerPrinciples 4 二、课程性质:专业基础课,必修 ❖ 编译程序(器)出现于上世纪50年代后期 (第一个高级语言1958年) ❖ 60年代~70年代是研究高峰期 ❖ 60年代中期开始在高校中开设课程 ❖ 80年代开始作为计算机科学与技术专业的 必修基础课程
计算机导论 算法初分心肝言初步 CC+源吉程必设计 语方诺法+算法 五 数据铂构 数据结构、算法+语言实现 王 算法分析与设计 算法+语言实现 编译原理 语言本身的实现 程序设计语言相关的课程设置 CompilerPrinciples
CompilerPrinciples 5
三、课程特点: 。充分体现了计算学科中抽象、理论和设计三个学科 形态 ÷该课程涉及多门课程的内容综合运用,涉及面广, 内容庞杂,学习艰难 ó程序设计语言、计算机体系结构、语言理论及算法等 6数据结构、离散数学 。该课程涉及的原理、方法和技术具有十分普遍的意 义 6每一个计算机科学与技术工作者的职业生涯中反复用到, “享用一辈子” ó这儿接受的训练很难在其他地方获得,如:抽象与形式 化方法、局部与全局优化方法、构造技术、证明方法等 6 CompilerPrinciples
CompilerPrinciples 6 三、课程特点: ❖ 充分体现了计算学科中抽象、理论和设计三个学科 形态 ❖ 该课程涉及多门课程的内容综合运用,涉及面广, 内容庞杂,学习艰难 程序设计语言、计算机体系结构、语言理论及算法等 数据结构、离散数学 ❖ 该课程涉及的原理、方法和技术具有十分普遍的意 义 每一个计算机科学与技术工作者的职业生涯中反复用到, “享用一辈子” 这儿接受的训练很难在其他地方获得,如:抽象与形式 化方法、局部与全局优化方法、构造技术、证明方法等
四、学习该课程的意义 ⑧编译程序是计算机系统不可缺少的重要组成 部分 ó对程序设计语言的设计与实现能有更深刻的理 解 6对程序设计语言有关理论有所了解 6从宏观上把握程序设计语言一掌握了编译原 理后,就不能再说:“某语言未学过,所以不 会” ó有助于快速理解、定位和解决程序调试与运行 中出现的问题 CompilerPrinciples
CompilerPrinciples 7 四、学习该课程的意义 ❖ 编译程序是计算机系统不可缺少的重要组成 部分 对程序设计语言的设计与实现能有更深刻的理 解 对程序设计语言有关理论有所了解 从宏观上把握程序设计语言——掌握了编译原 理后,就不能再说:“某语言未学过,所以不 会” 有助于快速理解、定位和解决程序调试与运行 中出现的问题
。编译方法与技术有着广泛应用 ó安全技术、程序理解、软件逆向工程、应用软件与软 件工具开发、软件测试与验证等 ÷编译课程蕴含着计算学科中解决问题的思路、抽 象和方法,这些与高等数学一样,使你“享用一 辈子” 。课程所涉及的内容至今非常活跃 6自然语言的翻译 6软件移植 6网络安全 6形式化方法 6形式语义学等 CompilerPrinciples
CompilerPrinciples 8 ❖ 编译方法与技术有着广泛应用 安全技术、程序理解、软件逆向工程、应用软件与软 件工具开发、软件测试与验证等 ❖ 编译课程蕴含着计算学科中解决问题的思路、抽 象和方法,这些与高等数学一样,使你“享用一 辈子” ❖ 课程所涉及的内容至今非常活跃 自然语言的翻译 软件移植 网络安全 形式化方法 形式语义学等
鉴于以上所述,作为计算机科 学与技术专业的学生必须学习和 掌握编译原理这门课程,当然由 于其综合性、处理问题的复杂性 等,学习起来有一定难度,这就 需要艰苦奋斗的精神和良好的学 习方法 CompilerPrinciples
CompilerPrinciples 9 鉴于以上所述,作为计算机科 学与技术专业的学生必须学习和 掌握编译原理这门课程,当然由 于其综合性、处理问题的复杂性 等,学习起来有一定难度,这就 需要艰苦奋斗的精神和良好的学 习方法
五、学习方法 ÷编译程序的构造是一个庞大而复杂的系统 工程,无论是概念还是理论、方法,对初 学者来说许多都是新的,学习起来会感到 困难大一些,这一点必须有充分认识,为 此建议学习方法上注意以下几点: CompilerPrinciples
CompilerPrinciples 10 五、学习方法 ❖ 编译程序的构造是一个庞大而复杂的系统 工程,无论是概念还是理论、方法,对初 学者来说许多都是新的,学习起来会感到 困难大一些,这一点必须有充分认识,为 此建议学习方法上注意以下几点: