执行上下文(AO、GO)和函数执行流程

本文介绍了JavaScript中的执行上下文(全局上下文GO和函数上下文AO)及其执行流程。详细阐述了GO和AO在产生时的步骤,包括变量和函数声明的处理以及代码的执行。此外,还讲解了函数执行的具体过程,如创建执行环境、建立作用链域、执行代码及销毁活动对象等。同时提供了一个例题辅助理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

执行上下文(AO、GO)和函数执行流程

  • 全局上下文GO

  • 函数上下文AO

https://www.cnblogs.com/xsg1/p/11131908.html

GO: 全局上下文,Global Object,它在全局代码执行前产生

产生的时候做了什么呢?分为以下几个步骤:

  1. 寻找变量声明
  2. 寻找函数声明,赋值
  3. 代码执行

AO: Activation Object 活跃对象,函数上下文,在函数执行前产生

产生的时候做了什么呢?分为以下几个步骤:

  1. 寻找形参和变量声明
  2. 实参赋值给形参
  3. 寻找函数声明,赋值
  4. 代码执行

例题

	  function test(a){
      console.log(a);
      var a = 1;
      console.log(a);
      function a(){};
      console.log(a);
          console.log(b);
      var b = function(){};
      console.log(b);
      function d(){}

    }
    test(2);

实际步骤:

	  function test(a){
          var a; // 函数声明提前
          // 应该还有一步:a = 2, 实参赋值给形参
          function a(){}; // 不过被覆盖了
          var b;
          function d(){};
          
      console.log(a); // function a(){} , 如果没有function a(){};会输出a=2
      a = 1;
      console.log(a); // 1
      console.log(a); // 1
          console.log(b); // undefined
      b = function(){};
      console.log(b); // function b(){}
    }
    test(2);

函数执行过程

  1. 为函数创建一个执行环境
  2. 复制函数的 [[scopes]] 属性中的对象构建起执行环境的作用链域
  3. 创建函数活动对象并推入执行环境作用链域的前端
  4. 执行代码
  5. 销毁执行环境和活动对象(闭包情况下活动对象仍被引用没被销毁)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值