编译原理笔记

编译原理

编译器结构:(目标程序为汇编语言)
在这里插入图片描述

每个阶段将源程序从一种表示转换成另一种表示。
随着编译器各个阶段的进展,源程序的内部表示不断地发生变化。

  1. 词法分析器:字符流->单词流

  2. 语法分析器:单词流->语法树

  3. 语义分析器:
    收集标识符的属性信息:
    类型(Type)
    种属(Kind)
    存储位置、长度

    作用域
    参数和返回值信息
    语义检查:
    变量或过程未经声明就使用
    变量或过程名重复声明
    运算分量类型不匹配
    操作符与操作数之间的类型不匹配

  4. 中间代码生成器:抽象语法树->中间表示(与平台无关的抽象程序)
    易于产生
    易于翻译成目标程序
    三地址码:temp1=cd;temp2=b+temp1;a=temp2
    四元式:(op, arg1, arg2, result);(
    , c , d , temp1);(+ , b, temp1 , temp2);(= , temp2 , - , a)

  5. 代码优化器:试图改进中间代码,以产生执行速度较快的机器代码
    temp1=cd;temp2=b+temp1;a=temp2
    change to:temp1=c
    d;a=b+temp1
    代码生成器:生成可重定位的机器代码或汇编代码
    temp1=c*d;a=b+temp1
    change to:Mov R2,c;Mul R2, d;Mov R1, b;Add R2, R1;Mov a, R2
    一个重要任务是为程序中使用的变量合理分配寄存器

  6. 符号管理表:
    基本功能是记录源程序中使用的标识符,
    并收集与每个标识符相关的各种属性信息,
    并将它们记载到符号表中。

  7. 错误处理器:
    处理方式:报告错误,应继续编译
    大部分错误在语法分析、语义分析阶段检测出来
    词法分析:字符无法构成合法单词
    语法分析:单词流违反语法结构规则
    语义分析:语法结构正确,但无实际意义

gcc与g++区别

简单来说,gcc与g++都是GNU(组织)的一个编译器。需要注意以下几点:

(1)gcc与g++都可以编译c代码与c++代码。但是:后缀为.c的,gcc把它当做C程序,而g++当做是C++程序;后缀为.cpp的,两者都会认为是C++程序。

(2)编译阶段,g++会调用gcc,对于c++代码,两者是等价的,但是因为gcc命令不能自动和C++程序使用的库联接,所以通常用g++来完成链接。

(3)编译可以用gcc/g++,而链接可以用g++或者gcc -lstdc++。因为gcc命令不能自动和C++程序使用的库联接(当然可以选择手动链接,使用命令如下),所以通常使用g++来完成联接。但在编译阶段,g++会自动调用gcc,二者等价。

gcc main1.cpp -lstdc++
gcc编译的四个步骤, 以最简单的helloWorld.c为例子
一步到位:gcc helloWorld.c
这条命令隐含执行了
(1)预处理
(2)编译
(3)汇编
(4)链接
这里未指定输出文件,默认输出为a.out

gcc编译C源码有四个步骤:
预处理 ----> 编译 ----> 汇编 ----> 链接
现在我们就用gcc的命令选项来逐个剖析gcc过程。

1. 预处理(Pre-processing)
在该阶段,编译器将C源代码中的包含的头文件如stdio.h添加进来
参数:”-E”
用法:gcc -E helloWorld.c -o helloWorld.i
作用:将helloWorld.c预处理输出helloWorld.i文件。
2. 编译(Compiling)
第二步进行的是编译阶段,在这个阶段中,gcc首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc把代码翻译成汇编语言。
参数:”-S”
用法:gcc –S helloWorld.i –o helloWorld.s
作用:将预处理输出文件helloWorld.i汇编成helloWorld.s文件。
3. 汇编(Assembling)
汇编阶段是把编译阶段生成的”.s”文件转成二进制目标代码“.o”文件
参数:“-c”
用法:gcc –c helloWorld.s –o helloWorld.o
作用:将汇编输出文件helloWorld.s编译输出helloWorld.o文件。
4. 链接(Link)
在成功编译之后,就进入了链接阶段。
用法:gcc helloWorld.o –o helloWorld
作用:将编译输出文件helloWorld.o链接成最终可执行文件helloWorld。
运行该可执行文件,出现正确的结果如下。
>>> ./helloWorld
Hello World!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 编译原理是针对计算机编程语言的研究,目的是将高级语言转化为机器语言并执行。编译原理笔记PDF是一份系统性的学习笔记,包含了编译原理的各个方面。这份学习笔记可以帮助学习者深入了解编译原理,掌握相关的技能。 编译原理笔记PDF通常包含以下几个方面的内容:编译原理的基本概念,编译器的结构与原理,语法分析器的设计与实现,语义分析器的设计与实现,中间代码生成和机器码生成,以及优化技术等。这些内容都是非常重要的编译原理知识点,可以帮助学习者理解编译原理的各个方面,并掌握相关的技术细节。 编译原理笔记PDF还可以提供一些编译原理实战案例,帮助学习者将所学知识应用到实际情况中。实际中有很多编译器与解析器需要我们开发,而这份学习笔记可以准确清晰地指导我们如何设计和开发这些编译器。 总之,编译原理笔记PDF是一份非常有价值的学习资料,可以帮助我们深入了解编译原理,掌握相关的技能,并将这些知识应用到实际情况中。 ### 回答2: 编译原理笔记PDF是一份非常全面的编译原理学习资料,其中详细介绍了编译原理的各个方面,包括词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成等。这些内容不仅涵盖了编译原理的基本理论概念和算法,还提供了许多实际的实现案例和实际开发中的工具。 对于想要学习编译原理的同学来说,编译原理笔记PDF是一个非常好的选择,它可以帮助同学们快速地掌握编译原理的相关知识和技能。通过对这份资料的学习,同学们能够从实际问题和实际应用的角度深入理解编译原理的相关概念和算法,同时掌握一些实用的工具和技术,从而更好地应对工作和学习中的编译问题。 总之,编译原理笔记PDF是一份非常有价值的学习资料,它能够帮助同学们更好地学习和理解编译原理的相关概念和算法,同时提供一些实际的工具和技术供同学们参考和应用。建议有相关需求的同学一定要好好利用这份资料,从中学到更多有用的知识和技能。 ### 回答3: 编译原理笔记 pdf是一本关于编译原理的学习资料,其中涵盖了编译原理的基础知识、重要概念、算法和分析等内容。编译原理是计算机科学中非常重要的一门学科,其研究的是如何将一种高级语言转化为低级语言,并使之在计算机中运行。编译原理涵盖的内容很广,包括词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成等等。 编译原理笔记 pdf可以帮助学习者更好地理解和掌握编译原理的知识,尤其是对于那些正在学习编译原理或者准备学习编译原理的人来说,是一本非常有价值的资料。它可以帮助学习者更深入地了解编译原理的基础概念,例如编译器、编译过程、语言处理器等等,同时也可以帮助学习者更准确地理解编译原理中的各种概念和算法,例如文法、自动机、LL(1)分析器、LR分析器等等。 总之,编译原理笔记 pdf是一本非常实用、有价值的学习资料,它对于那些正在学习或者准备学习编译原理的人来说,是一本非常有趣和有用的书籍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HelloHypatia

希望自己的总结对大家有所帮助!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值