美文网首页
JS进阶系列之执行上下文

JS进阶系列之执行上下文

作者: McRay | 来源:发表于2017-06-13 20:08 被阅读0次
function test(){
     console.log(a);//undefined;
     var a = 1;
}
test();

也许你会遇到过上面这样的面试题,你只知道它考的是变量提升,但是具体的原理又知道吗?所以我觉得很有必要搞明白底层的原理,才能加深理解,其实围绕的就是执行上下文的概念。

什么是执行上下文?

当控制器转到可执行的代码时,会进入该代码对应的执行上下文,可以理解为该代码对应的一个执行环境,就叫做执行上下文。

在JavaScript中运行环境有三种,分别是:

  • 全局环境:JavaScript代码执行起来,首先就是进入全局环境。
  • 函数环境:当函数被调用执行时,就会进入函数中执行。
  • eval

所以在一个JavaScript程序中,就会产生多个不同的执行上下文,这时候就需要用到前面提到的数据结构来管理了,我们称之为调用栈。当代码在执行过程中,遇到上面说的三种情况,就会产生三种执行上下文,然后分别压入调用栈中,等一个执行上下文执行完毕,弹出栈,才能执行下一个执行上下文中的代码,这就是栈结构的特点。

执行上下文的特点

  • 单线程,其实javascript就是单线程,所以很好理解。
  • 同步执行,同步就是按顺序,不能同时执行。
  • 全局上下文只有一个,它在浏览器关闭时才会弹出栈。
  • 函数的执行上下文的数目没有限制。
  • 每次某个函数被调用时,就会有新的执行上下文,即使是调用的自身函数。
demo01
function f1(){
     var n = 999;
     function f2(){
         alert(n);
    }
    return f2;
}
var result = f1();
result();//999

我以上面这样一个例子讲解,执行上下文调用栈中的创建过程

image.png

执行上下文的生命周期

image.png

如图所示,主要分为两个阶段,一个是创建阶段,一个是执行阶段

创建阶段:
  • 生成变量对象,后面会讲解
  • 建立作用域链
  • 确定this指向
执行阶段:
  • 变量赋值
  • 函数引用
  • 执行其他代码
执行完毕后弹栈,等待回收

变量对象和活动对象的区别就在于,执行周期不一样,在创建阶段叫做变量对象,在执行阶段叫做活动对象。

变量对象

image.png

变量对象的创建主要有三个阶段:

  • 1、创建arguments对象。
  • 2、检查function函数声明创建属性。在VO对象中以函数名建立一个属性,属性值为函数的地址。如果函数名的属性已经存在了,那么该属性将会被新的引用所覆盖。
  • 3、检查var变量声明创建属性。在VO对象中以变量名建立一个属性,属性值为undefined。为了防止同名的属性值会被修改为undefined,则会直接跳过,原属性值不会被修改。

举个变量提升和函数提升的例子,就明白了

demo02
function test(){
      console.log(a);
      console.log(foo());
      var a = 1;
      function foo(){
             return 2;
     }
}
test();

这是一个典型的变量提升和函数提升的例子,最后会输出undefined和2,接下来以执行上下文的生命周期来讲解,

创建过程
testEC = {
      VO:{},
      scopeChain:{},
      this:{}
}
VO = {
     arguments:{},
     foo:<foo reference>,
     a:undefined
}
执行阶段
VO->AO
AO={
      arguments:{},
     foo:<foo reference>,
     a:2
}
等同于
function test(){
      function foo(){
           return 2;
     }
     var a;
     console.log(a);
     console.log(foo());
     a = 1;
}
test();

通过上面知识的讲解,进一步了解到了变量提升和函数提升的底层原理,对后面知识的学习也做了铺垫。

相关文章

  • JS进阶系列之执行上下文

    也许你会遇到过上面这样的面试题,你只知道它考的是变量提升,但是具体的原理又知道吗?所以我觉得很有必要搞明白底层的原...

  • 闭包和this

    执行上下文 执行上下文是什么 可以简单理解执行上下文是js代码执行的环境,当js执行一段可执行代码时,会创建对应的...

  • js 随笔

    js 执行机制: js执行上下文: 只有理解了js 执行上下文才能更好的理解 js变量提升以及 作用域和闭包 所谓...

  • JS中的执行上下文

    执行上下文 1. 定义 执行上下文就是js代码被解析和执行时所在环境的抽象概念,js的所有代码都是在执行上下文中运...

  • 函数的底层处理机制

    js上下文分类 js上下文(哪一个区域下执行)分类: 1.全局上下文EC(G) 2.函数执行形成...

  • 执行上下文(个人笔记)

    本文参考:javaScript执行上下文和执行上下文栈一篇文章看懂JS执行上下文什么是执行上下文?什么是调用栈? ...

  • 我的JS笔记 -- 执行上下文

    执行上下文,就是Js执行的时候的一个运行环境/作用域(scope)。执行上下文决定了Js执行过程中可以获取哪些变量...

  • javascript-执行上下文(执行上下文环境)

    执行上下文: 当出现js代码时,就出现了执行上下文,或叫做执行上下文环境。一般来说,执行上下文完成以下工作: 1....

  • JavaScript进阶-内存空间详解(双十一过后的一更)

    前言 本章继《JavaScript进阶-执行上下文栈和变量对象(一周一更)》之后继续深入学习JS的基础知识. 上面...

  • JavaScript进阶-执行上下文栈和变量对象(一周一更)

    前言 在阅读本篇文章之前, 请先了解执行上下文及执行栈的基础知识点, 移步《JavaScript进阶-执行上下文(...

网友评论

      本文标题:JS进阶系列之执行上下文

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