美文网首页
[编译原理] 第一章

[编译原理] 第一章

作者: 耿杰 | 来源:发表于2019-08-09 13:55 被阅读0次

1.1节的练习

练习1.1.1: 编译器和解释器之间的区别是什么?

编译器 解释器
  • 1、执行代码的时机:编译器会先把源程序翻译成目标程序,用户再通过目标程序执行代码,执行时是不需要编译器的,直接在平台上执行。解释器是边解释边执行代码。
  • 2、源程序错误:编译器是在翻译源程序过程中就发现错误。解释器是在程序运行中,才能发现错误。

练习1.1.2:编译器相对于解释器的优点是什么?解释器相对于编译器的优点是什么?

  • 编译器优点

    • a、生成的目标程序执行速度快。(在翻译的过程中会对源代码进行优化并生成目标程序
  • 解释器优点

    • a、解释器错误断诊效果通常比编译器更好,因为它是逐个主句地执行源程序。
    • b、可以让用户很方便地进行跨平台处理。一个源程序可以在不同操作系统上执行(有细微地代码差别,比如目录分隔符)。

练习1.1.3:在一个语言处理系统中,编译器产生汇编语言而不是机器语言的好处是什么?

  • 因为汇编语言比较容易来输出和调试。

练习1.1.4:把一种高级语言翻译成为另一种高级语言的编译器称为源到源(source-to-source)的翻译器。编译器使用C语言作为目标语言有什么好处?

  • 因为在大部分计算机上都有C编译器可用,这使得目标程序可以在所有这些系统上执行,代价是需要一次额外的编译才能得到最终的目标程序。

练习1.1.5:描述一下汇编器所要完成的一些任务。

  • 把汇编代码生成可重定位的机器代码。

1.3节的练习

练习1.3.1:指出下面的术语:可以被用于描述下面的哪些语言

1、强制式的
2、声明式的
3、冯 诺伊曼式的
4、面向对象的
5、函数式的
6、第三代
7、第四代
8、脚本语言
1、C
2、C++
3、Cobol
4、Fortran
5、Java
6、Lisp
7、ML
8、Perl
9、Python
10、VB

答案

1、强制式的: 另一种语言分类方式把程序中指明"如何完成一个计算任务的语言"
      C、C++、Java

2、声明式的:把程序中指明要进行"哪些"计算的语言
      ML 

3、冯 诺伊曼式的:是指以冯 诺伊曼式计算机体系结构为计算模型的程序设计语言
      C、Fortran 

4、面向对象的:指的是支持面向对象编程的语言,面向对象编程是指一组相互作用的对象组成程序的编程风格。
      C++\Java

5、函数式的
       ML、Lisp

6、第三代:通过语言的代来分类
       Cobol、Fortran、C、C++、Java、VB

7、第四代:通过语言的代来分类
        
8、脚本语言:是具有高层次运算符的解释型语言,它通常被用于把多个计算过程"粘合"在一起,这些计算过程被称为脚本。
      Python、VB、Perl

1.6节练习

练习1.6.1:对图中的块结构的C代码,指出赋给 w, x, y和z的值.

练习1.6.1

解答:

w:13 x:11 y:13 z:11

练习1.6.2: 对图中的块结构的C代码,指出赋给 w, x, y和z的值。

练习1.6.2

解答

w:9 x:7 y:13 z:11

练习1.6.3: 对于以下的块结构代码,假设使用常见的声明的静态作用域规则 ,给出其中12个声明中的每一个的作用域.

{  int w, x, y, z;          /** 块B1 */
        {   int x, z;       /** 块B2*/
            {   int w, x;   /** 块B3 */ }
        }
        {   int w, x;       /** 块B4 */
            {   int y, z;   /** 块B5 */ }
        }
 }

解答

块B3中的w、x 。只在块B3作用域内
块B5中的y、z。只在块B4作用域内
块B2中的x、z。作用域在 块B2和块B3内
块B4中的w、x。作用域在 块B4和块B5内
块B1中的w。 作用域在块B1、块B2和块B5内
块B1中的x。作用域在 块B1和块B5内
块B1中的y。作用域在 块B1、B2、块B3和块B4内
块B1中的z。作用域在 块B1、块B3和块B4内

练习1.6.4:下面的C代码的打印结果是什么?

#define a (x+1)

int x = 2;
void b() {
    x = a;
    printf("%d\n", x);
}
void c() {
    int x = 1;
    printf("%d\n", a);
}

int main() {  
    b();
    c();    
    return 0;
}

解答

3
2

相关文章

  • 读书笔记--你所不知道的js(上卷)

    第一章 编译原理 js是一门编译语言 传统编译语言流程: 分词/词法分析:把字符串分解成有意义的代码块 解析/语法...

  • #编译原理打卡01

    今天是编译原理的第一次课,讲了第一章,第一章比较简单,考点很简单: 1.翻译程序 翻译分为两种:编译程序和解释程序...

  • 编译原理

    编译原理 标签(空格分隔): 编译原理 编译和解释 编译 整个程序全部翻译结束之后,程序才能开始运行;编译和运行是...

  • 《你不知道的JavaScript(上)-作用域和闭包》学习笔记

    1.编译原理: (1)编译器、作用域、引擎 编译器会忽略重复声明 编译原理(p7): 例如:var a=2,编译器...

  • 《深入解析Hello,World》 :第三章 java源代码是怎

    javac实现原理 编译器原理

  • 编译原理(第一章)

    第一章:引论 1.1语言处理器 预处理器:源程序可能被分割成多个模块,并存放于多个文件中,预处理器将其聚合在一起 ...

  • 编译原理第一章

    草稿 1.介绍编译器和解释器的区别,以及各自优点2.介绍编译器的基本结构:词法分析(token stream),语...

  • [编译原理] 第一章

    1.1节的练习 练习1.1.1: 编译器和解释器之间的区别是什么? 1、执行代码的时机:编译器会先把源程序翻译成目...

  • 【MOOC:编译原理】第一章 编译概述

    第一讲 编译器概述 第二讲 编译器结构 编译器具有非常模块化的高层结构 前端:词法分析, 语法分析 后端:指令生成...

  • 编译原理总结提炼

    一、前言 编译原理是大学一门计算机基础课程,学习了编译原理并不意味着可以写出一个编译器,但学习编译原理可以给我们程...

网友评论

      本文标题:[编译原理] 第一章

      本文链接:https://www.haomeiwen.com/subject/zpfcjctx.html