编译器设计01-入门概述

编译器作用概述

源代码 → 编译器 目标代码 源代码\xrightarrow{\ \ \ 编译器\ \ \ }目标代码 源代码 编译器 目标代码

编译阶段概述

编译处理包括两个阶段:前端处理后端处理 ,中间过程生成语法树

编译处理:源代码 → 语法树 → 目标代码 编译处理:源代码\xrightarrow{{}}语法树\xrightarrow{{}}目标代码 编译处理:源代码 语法树 目标代码

前端处理 : 源代码 → 分析 语法树 前端处理:源代码\xrightarrow{\ 分析\ }语法树 前端处理:源代码 分析 语法树

后端处理 : 语法树 → 综合 目标代码 后端处理:语法树\xrightarrow{\ 综合\ }目标代码 后端处理:语法树 综合 目标代码

编译过程概述

编译好比英文文章翻译中文文章,源代码是英文文章,目标代码是中文文章,语法树体现翻译要点各种关系,是你翻译过程的主要笔记。从高级语言到机器语言,从书本语言到笔记语言,编译器的好坏,决定了翻译的质量。语义不变是红线,在此前提下要尽量简洁清楚不说废话,让人好懂。

前端处理概述

前端处理:词法分析语法分析语义分析

前端处理犹如阅读英文文章,往往我们需要先理清文章中各个词的意思,这类似词法分析;再梳理整篇文章的脉络,这类似语法分析;再检查文章的议论是否逻辑正确、叙述是否前后连贯、抒情是否价值观一致,这类似语义分析。

后端处理概述

后端处理:中间代码生成目标代码生成贯穿各个阶段的优化

后端处理犹如得出中文文章,当阅读完英语文章后,你的脑海中就有清晰的"中间代码"了,想写作的时候就心中有数,核心论点是什么,论据是什么,文章就有个层次,你会通过合理规范的形式把它们统一起来,经过翻译润笔(优化加工)便得到最后的文章中文译本。

相关推荐
cup1118 小时前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi0020 小时前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏
python·游戏
copyer_xyf1 天前
Agent 流程编排
后端·python·agent
copyer_xyf1 天前
Agent RAG
后端·python·agent
copyer_xyf1 天前
【RAG】向量数据库:milvus
后端·python·agent
copyer_xyf1 天前
Agent 记忆管理
后端·python·agent
星云穿梭2 天前
用Python写一个带图形界面的学生管理系统——完整教程
python
金銀銅鐵2 天前
用 Pygame 实现 15 puzzle
python·数学·游戏