编译原理笔记 2025/4/22

article/2025/9/6 17:45:17

基本概念

汇编语言与高级程序设计语言的关系/汇编干嘛的:高级语言与硬件无关,汇编语言的定义与CPU的指令系统直接相关。只要将高级语言编写的程序等价地转换成特定硬件平台所支持的方式来实现(汇编程序或机器指令序列),那么软件设计师就不必为每种硬件平台重写编写具有相同功能的软件。

编译器:1.狭义的编译器,将高级语言翻译成等价的可执行指令序列(或先翻译成汇编,再翻译成可执行指令序列);2.广义的编译器,只要程序在功能和含义上与原来的程序一致就行,(不管能不能执行。)

解释器:除了编译执行之外,还有解释执行。由于高级语言和底层指令系统差别较大,因此要实现对程序的解释执行,必须在程序解释执行的过程中进行程序的翻译。由于不是被CPU直接执行,解释执行的程序在性能上比编译执行的程序慢。

虚拟机:如java虚拟机,定义了一套标准的指令集合(字节码)。java编译器将java程序翻译成具有相同功能的字节码程序,然后由虚拟机对字节码程序进行解释执行。(字节码和CPU二进制指令接近,解释的就更快。)Java编译器还采用即时编译JIT提高执行效率。

编译技术:词法分析、语法分析、语义分析、中间代码生成、代码优化、目标代码生成。

  1. 词法分析:将源代码转换为词法单元序列(词法分析程序又称为扫描程序,对源程序每个字符进行线性读取)
  2. 语法分析:构建(抽象)语法树AST。(成功表明程序符合语法,否则存在某种语法错误)
  3. 语义分析:验证语义规则。(语法分析只给了程序格式正确性的要求,语义则给出了程序含义正确的规定)
  4. 中间代码生成:生成中间表示(获得了程序语义信息理论上就可以将其翻译成汇编代码或二进制机器代码。不过只是理论上这样,实际上要先把程序转换为某种形式的中间表示或中间代码,对其进行性能、存储优化处理,再翻译成可执行代码)(一般采用抽象语法树AST中间表示,AST前面进行语法、语义分析时已经逐步建立和完善了)
  5. 代码优化:优化以提高性能(执行时间与存储空间两方面)
  6. 目标代码生成:输入优化后中间代码,产生汇编代码或目标机器代码的指令序列(具体操作是为每个变量分配具体存储地址,使用实际机器的寄存器,将每个中间代码指令映射到一条或一组等价且高效的机器指令等)

编译器按功能分前端和后端:

  • 前端:词法分析、语法分析、语义分析
  • 后端:代码优化、目标代码生成等
  • 前后端通过中间表示和中间代码进行信息交换

形式语言与自动机理论基础

词法分析

语法分析——自顶向下分析方法

三个重要集合

自顶向下语法分析条件

LL1分析方法

求三个集合例子👇

E → TE'
E' → +TE' | ε
T → FT'
T' → *FT' | ε
F → (E) | i

构造LL(1)分析表👇

分析表构造好后分析👇

判断是否满足LL(1)文法的例子👇

语法分析——自底向上分析方法

简单优先分析

1.简单优先文法及其优先关系

2.矩阵的构造

3.简单优先分析算法

例👇

判断是否是简单优先文法👇

完整例子👇

LR分析法

这里的L表示从左向右扫描输入串,R表示构造一个最右推导的逆过程。

由于LR(k)分析方法对文法的限制很少,因而大多数能用上下文无关文法描述的程序设计语言都可用LR分析法进行有效的分析。

因此,LR分析法是当前最一般的语法分析方法。

LR(0):已知文法,构造状态机和分析表的例子👇

例子👇

语义分析和符号表

中间代码生成

中间代码优化


http://www.hkcw.cn/article/YLqAHEJDWO.shtml

相关文章

(ICML-2025) RIFLEx:视频扩散Transformer中长度外推的“免费午餐”

RIFLEx:视频扩散Transformer中长度外推的“免费午餐” paper title:RIFLEx: A Free Lunch for Length Extrapolation in Video Diffusion Transformers paper是THU发表在ICML 2025的工作 Code:链接 Abstract 近期视频生成的进展使模型能够合成高质量的分…

树莓派超全系列教程文档--(52)如何启用VNC功能

如何启用VNC功能 使用 VNC 共享屏幕启用 VNC 服务器以图形方式启用 VNC 服务器在命令行上启用 VNC 服务器 连接到 VNC 服务器 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 使用 VNC 共享屏幕 有时,使用设备进行物理操作并不方便。…

TDengine 运维——巡检工具(安装工具)

背景 TDengine 的安装包自带安装脚本,但无法基于集群进行自动化安装部署,本文档旨在说明如何使用安装工具进行 TDengine 的集群式安装部署。 安装工具支持功能 安装方式详细说明单节点安装部署单节点环境安装部署 TDengine集群安装部署集群环境安装部…

Qt Creator调用Python代码

Qt Creator下调用Python代码 在Qt编写的上位机,现在可能经常用到Python相关的代码。本篇记录Qt Creator中调用Python的一种方法。 Python使用的版本为 3.9.10,(安装参考:Python3.9的安装和配置) Qt 使用的版本为5.14.2,(Qt的安装可以参考网上的安装案例:Qt 5.14安装…

政策+技术双轮驱动:MiC建筑如何成为“好房子”建设的破局之道

在建筑行业不断追求创新与可持续发展的今天,模块化集成建筑(Modular Integrated Construction,简称MiC)正逐渐崭露头角,成为推动行业转型升级的重要力量。近日,全国政协常委、人口资源环境委员会副主任&…

Python Day37

Task: 1.过拟合的判断:测试集和训练集同步打印指标 2.模型的保存和加载 a.仅保存权重 b.保存权重和模型 c.保存全部信息checkpoint,还包含训练状态 3.早停策略 1. 过拟合的判断:测试集和训练集同步打印指标 过拟合是指模型在训…

2025年全国青少年信息素养大赛 scratch图形化编程挑战赛 小低组初赛 内部集训模拟题解析

2025年信息素养大赛初赛scratch模拟题解析 博主推荐 所有考级比赛学习相关资料合集【推荐收藏】 scratch资料 Scratch3.0系列视频课程资料零基础学习scratch3.0【入门教学 免费】零基础学习scratch3.0【视频教程 114节 免费】 历届蓝桥杯scratch国赛真题解析历届蓝桥杯scr…

Linux环境基础开发工具->gcc/g++

引入:gcc/g是什么? 在上篇博客我们知道,vim是一个编辑器,vim负责的是代码的编辑;而gcc/g是一个编译器,负责的就是代码的编译!gcc负责C语言代码的编译,而g负责c代码的编译&#xff0…

云原生与DevOps融合实践:加速企业数字化转型的加速器

📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:为什么“云原生DevOps”是当下最强组合? 在传统软件交付模式逐步被淘汰的当下,越来…

孙颖莎王曼昱出战WTT美国站女双 拉斯维加斯再携手

2025年WTT美国大满贯将于7月3日至13日在拉斯维加斯奥尔良体育馆及美高梅大酒店会议中心举行。孙颖莎和王曼昱将搭档出战女双正赛。在不久前结束的多哈世乒赛女单决赛中,孙颖莎以4比3的大比分险胜王曼昱,成功卫冕。责任编辑:zx0176

基于51单片机和8X8点阵屏、独立按键的射击消除类小游戏

目录 系列文章目录前言一、效果展示二、原理分析三、各模块代码1、8X8点阵屏2、独立按键3、定时器04、定时器1 四、主函数总结 系列文章目录 前言 使用的是普中A2开发板。 【单片机】STC89C52RC 【频率】12T11.0592MHz 【外设】8X8点阵屏、独立按键 效果查看/操作演示&#x…

ubuntu22.04安装docker

1. 准备工作 更新系统软件包索引 sudo apt update2. 卸载旧版本 Docker(可选) 清理旧版 Docker 及相关依赖 sudo apt-get remove docker docker-engine docker.io containerd runc3. 设置 Docker 仓库 安装依赖工具 (apt-transport-https, ca-certi…

burpsuit抓包完整示例

1.确保浏览器(这里使用的是火狐浏览器)和burpsuit配置完整(有需要留言),配置完整包括jdk安装,配置环境变量,下载burp,下载并导入证书,ip端口一致,代理能正常打开。 2.注意…

其他 | 边缘端应用的轻量级优化调研

1.调研目标 由于边缘计算场景的性能受限,无法提供与常规服务器相同或略低的环境,因此对我们的上层业务应用有着较高的资源要求。 目前我们的应用程序基于 Oracle JDK(开发者端)与 OpenJDK(生产环境)进行开…

Shell 脚本常用命令笔记

一、系统配置命令 1. 主机名设置 文件方式 修改文件:vim /etc/hostname,写入新主机名(如czg.easylee.org)。生效方式:需重新打开 Shell 或重启系统。 命令方式 即时生效命令:hostnamectl set-hostname 新…

不规则瀑布流布局拖拽重排序

因为业务,所以需要用flutter去实现一种不规则图形的瀑布流,但是同时需要支持拖拽并重新排序。效果类似如下。 查询过现有的插件,要么是仅支持同样大小的组件进行排序,要么就是动画效果不是很满意,有点死板,…

线程de安全性备忘

文章仅供学习参考 线程安全的本质定义 public class Counter {private int value 0; // 共享资源// 线程安全方法public synchronized void increment() {value; // 原子操作} }原子性(Atomicity):操作不可分割(如 synchroniz…

进行性核上性麻痹健康护理全指南:从症状管理到生活照护

进行性核上性麻痹(PSP)是一种罕见的神经退行性疾病,主要影响运动、平衡及眼球运动功能,常表现为步态不稳、吞咽困难、眼球上视受限、情绪改变等。由于目前尚无根治方法,科学的健康护理对延缓病情进展、提升患者生活质量…

[智能算法]蚁群算法原理与TSP问题示例

目录 ​编辑 一、生物行为启发的智能优化算法 1.1 自然界的群体智能现象 1.2 人工蚁群算法核心思想 二、算法在组合优化中的应用演进 2.1 经典TSP问题建模 2.2 算法流程优化 三、TSP问题实战:Python实现与可视化 3.1 算法核心类设计 3.2 参数敏感性实验 3.3 可视化…

安卓学习笔记-数据存储

阅读说明 本文是基于上一篇文章《安卓学习笔记-声明式UI》的后续。上篇文章实现了UI层以及业务逻辑层ViewModel的解耦。本篇关注的是数据存储层与业务逻辑层的解耦。 补充知识StateFlow 在 MVVM 架构中如何使用 Kotlin 协程的 StateFlow 来管理和暴露 UI 状态。 private va…