码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 3.4 - 编译与解释 3.5 - 编译过程 3.8 - 文法


    目录

    一、编译与解释

    1、解释程序(解释器)

    2、编译程序(编译器)

    3、如何区分编译程序和解释程序

    4、考法1:编译器与解释器的区别

    5、考法2:反编译

    二、编译过程

    1、相关概念

    2、编译器的组成

    3、编译过程

    4、考法1:编译必须的阶段

    5、考法2:符号表管理和出错处理的特点

    6、考法3:中间代码的特点

    7、考法4:静态/动态语义的内容

    三、文法

    1、文法定义

    2、文法推导(考点)


    一、编译与解释

    1、解释程序(解释器)

    • 不生成目标程序。

    • 解释的程序在运行时需要源代码或者等效的中间代码参与,而且来控制层在解释器上面。

    2、编译程序(编译器)

    • 将源程序编译成有目标计算机特征的目标程序。

    • 在计算机直接运行目标程序就行,不需要源程序和编译程序参加。

    3、如何区分编译程序和解释程序

    • 看是否生成目标程序。

    4、考法1:编译器与解释器的区别

    5、考法2:反编译

    • 反编译:不能还原出原程序,只能还原到一个中间状态。通过反编译有助于我们理解设计者的一些思路。

    二、编译过程

    1、相关概念

    • 语句

            用来描述程序中运算步骤,控制结构,数据传输。

    • 语法

            程序的基本符号组成的程序,要符合各个语法的要求。

    • 语义

            概念:不同的语法结构表示出来的含义。

    分类:静态语义、动态语义。

    1、静态语义:程序在编译过程中就需要明确的语义。在编译的时候可以确定程序语法结构的含义。

    2、动态语义:需要运行这个程序,才能确定语法结构的含义。也就是编译完成的程序仍会存在动态语义的错误。

    • 语用

            程序与使用者之间的关系。 

    2、编译器的组成

    • 四个必备部分:词法分析、语法分析、语义分析、目标代码生成

    • 两个不必须项:中间代码生成、代码优化。如果编译器简单,就不会包含这两部分。

    3、编译过程

    词法分析:主要是对源程序从前到后,从左到右进行逐个字符的扫描,识别出一个一个的单词。所以通过编译的程序也就是通过词法分析的程序一般不存在词法错误。

    语法分析:在词法分析的基础上,按照看语法规则,去检查这些单词是否符合规范,在表达上形成一个正确的程序。所以通过编译的程序也就是通过语法分析的程序一般不存在语法错误。

    语义分析:在语法分析的基础上,检查程序的静态语义,主要是对数据类型进行分析和检查。

    中间代码生成:根据语义分析输出对应的中间代码。

    代码优化:对中间代码进行适当的优化。

    目标代码生成:根据目标计算机的指令特点生成对应的指令代码。这就将源程序编译成符合计算机特征的一些指令。

    出错管理:贯穿整个编译过程中的错误管理。

    符号表管理:主要记录源程序中各种符号的必要信息,以辅助我们进行语义的正确性检查,以及在编译过程中能够快速的进行查找、修改、插入等相关的操作。贯穿整个编译过程。

    4、考法1:编译必须的阶段

    5、考法2:符号表管理和出错处理的特点

    6、考法3:中间代码的特点

    7、考法4:静态/动态语义的内容

    三、文法

    1、文法定义

    2、文法推导(考点)

    • S:开始。
    • S-A0|B1:S可以用A0或者B1代替;
    • A-S1|1:A可以用S1或者1代替;
    • B-*S0|0:B可以用S0或者0代替;
  • 相关阅读:
    [PaddlePaddle飞桨] PaddleDetection-通用目标检测-小模型部署
    pytorch中的池化函数
    【分层强化学习】HIRO:Data-Efficient Hierarchical Reinforcement Learning
    Mac安装nacos超详细步骤|解决打不开http://127.0.0.1:8848/nacos
    SpringMVC进阶:常用注解、参数传递和请求响应以及页面跳转
    .NET C# 程序自动更新组件
    Pymoo:优化算法收敛性的实例分析
    Python 编程秘籍:掌握这些,你还会担心写不出高效代码吗?
    docker容器安装MySQL,navicat无法连接报错(10060/10061错误)
    【Django | 开发】 Rest Framework 开放API
  • 原文地址:https://blog.csdn.net/qq_46071165/article/details/126240044
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号