码迷,mamicode.com
首页 > 编程语言 > 详细

脚本语言与编译型语言

时间:2018-10-12 01:20:07      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:分割   抽象语法树   为什么   脚本语言   执行   理解   cpu   需要   解释   

不同

  • 编译型语言:
    • 编译型程序所生成的指令时二进制形式的机器码和操作数, 就是所谓的二进制流, 二进制程序是CPU可以直接识别执行的
  • 解释性语言:
    • 脚本语言的解释器是二进制形式的, 可以被CPU直接识别的, 但是脚本解释器的输入是脚本语言字符串, CPU执行脚本语言解释器, 而脚本语言解释器去执行脚本语言, 中间隔了一层, 脚本程序是通过CPU间接运行的

    • 脚本语言的两大类:
      • 一边解释一边执行-->所以不会有opcode生成
      • 分析整个文件后创建抽象语法树生成opcode, 有了指令之后让解释器去执行opcode(包括操作码和操作数), 这就相当于CPU执行汇编语言一样
      • ==== 华丽的分割线 =====
      • 解释器可以理解为一个虚拟机, 虚拟机的有两类, 一个是类似于Python的虚拟机一样只模拟CPU; 另一个是类似于VMware一样, 用来虚拟操作系统的, 使用数组作为寄存器, 文件作为硬件

为什么脚本语言会慢

  • 脚本语言需要两次IO, 而编译型则需要一次IO
    • 在脚本语言中, CPU将脚本解释器从硬盘加载到内存中, 脚本解释器又将脚本程序从硬件中加载到内存中; 而编译型语言本身就是一个二进制程序, CPU将其加载到内存中, CPU就直接执行了
    • 另一个原因还跟脚本语言的解释方式
      • 在一边解释一边执行的脚本语言中:
        • CPU操作的是字符串, 没有编译的操作, 我们只要比较字符串需要时间复杂度为O(n), 而数字为O(1), 所以需要比较n次才能确定一个操作码, 太慢了
      • 在先编译再执行中(Python)
        • 将文件编译, 里面的字符串都转换为数字, 这样时间复杂度就是O(1)了, 更快了

脚本语言与编译型语言

标签:分割   抽象语法树   为什么   脚本语言   执行   理解   cpu   需要   解释   

原文地址:https://www.cnblogs.com/megachen/p/9775845.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!