chrome+执行js填表_64 JS引擎和代码执行

JS引擎和代码执行

JS引擎

JS引擎举例

  • Chrome 用的是用 C++ 编写的 V8 引擎。
  • 网景用的是 SpiderMonkey, 后被 Firefox 使用,也是用 C++ 编写的。
  • Safari 用的是 JavaScriptCore。
  • IE 用的是 Chakra(JScript9)。
  • Edge 用的是 Chakra(JavaScript)。
  • Node.js 用的是 V8 引擎。

主要功能

  • 编译:把 JS 代码翻译为机器能执行的字节码或机器码。
  • 优化:改写代码,使其更高效。
  • 执行:执行上面的字节码或者机器码。
  • 垃圾回收:把JS用完的内存回收,方便之后再次使用。

执行 JS 代码

准备工作

  • 提供 API:window/document/setTimeout
  • 上面这些东西都不是 JS 自身具备的功能,我们把这些功能称为运行环境 runtime env .
  • 一旦我们把 JS 放进页面,就开始执行 JS。

内存图

  • JS代码在内存中运行。

87367ef23740dd39bf5d4fb8245fd1eb.png

红色区域

作用

  • 红色专门用来存放数据。
  • 红色区域并不存变量名,变量名在不知什么区(不同浏览器中的名称不同)。
  • 每种浏览器的分配规则并不一样。
  • 上图的区域并不完整,没有画 调用栈、任务队列 等区域。

Stack 和 Heap

  • 红色区域分为 Stack 栈和 Heap 堆。
  • Stack 区特点:每个数据顺序存放。
  • Heap 区特点:每个数据随机存放。

3c98a37dc1d2d519fe8cf3e504a7a150.png

示例

代码

        var a = 1;
        var b = a;
        var person = {
            name:'frank',
            child:{
                name:'jack'
            }
        }
        var person2 = person;

abb67cb550bf26f62668b057562ea96d.png

0760b017f5cdcba1276ce23f9e4bbf12.png

159aed9262e1a727934988a5f3b9cf39.png

57d256323a2bbf64c6b026287adb26dc.png

规律

  • 数据分两种:非对象和对象。
  • 非对象都存在 Stack 。
  • 对象都存在 Heap 。
  • 数组和函数皆为对象。
  • = 号总是会把右边的东西复制到左边。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值