`

深入--变量对象

 
阅读更多

《深入--执行上下文栈》中提到,当javascript执行一堆可执行代码(executable code)时,会创建相应的执行上下文(execution context)

 

每个执行上下文,都有三个重要属性:

 

变量对象(Variable Object,VO)

作用域链(Scope Chain)

this

 

这篇重点讲创建变量对象的过程

 

变量对象

变量对象是与执行上下文相关的数据作用域,存储了在上下文中定义的变量和函数声明

因为不同执行上下文下的变量对象稍有不同,所以我们来聊聊全局上下文下的变量对象和函数上下文下的变量对象

 

全局上下文

我们先了解一个概念叫全局对象,在W3School中也有介绍:

 

全局对象是预定义的对象,作为javascript的全局对象和全局属性的占位符。通过使用全局对象,可以访问所有其他预定义的对象、函数和属性

在顶层javascript代码中,可以用关键字ths引用全局对象,因为全局对象是作用域链的头,这意味着所有非限定性的变量和函数名都会作为该对象的属性来查询

例如,当javascript代码引用parseInt()函数时,它引用的是全局变量的parseInt属性。全局对象是作用域链的头,这意味着在顶层javascript代码中声明的所有变量都将称为全局对象的属性

 

如果看的不是很懂的话,可以分成几点来看全局对象

1.在顶层js代码中,可以通过this引用,在客户端js中,全局对象就是Window对象。

console.log(this);

2.全局对象是由Object构造函数实例化的一个对象

console.log(this instanceof Object);

3.预定义了一堆函数和属性

console.log(Math.random());

console.log(this.Math.random());

4.作为全局变量的宿主

var a = 1;

console.log(this.a);

5.客户端js中,全局对象有window属性指向自身

var a = 1; 

console.log(window.a);

this.window.b = 2;

console.log(this.b);

 

花了一个大篇幅来介绍全局对象,其实就想说:全局上下文中的变量对象就是全局对象啊!

 

函数上下文

 

在函数上下文中,我们用活动对象(activation object,AO)来表示变量对象

 

活动对象和变量对象其实是一个东西,只是变量对象是规范上的或者说是引擎实现上的,不可再javascript中访问,只有当进入一个执行上下文中,这个执行上下文的变量对象才会被激活,所以才叫activation object,而只有被激活的变量对象,也就是活动对象上的各种属性才能被访问

 

活动对象是在进入函数上下文时刻被创建的,它通过函数的arguments属性初始化。arguments属性值是Arguments对象

 

执行过程

 

执行上下文的代码会分成两个阶段进行处理:分析和执行,我们也可以叫做:

1.进入执行上下文

2.代码执行

 

进入执行上下文

 

当进入执行上下文时,这时候还没有执行代码

变量对象会包括:

1.函数的所有形参(如果是函数上下文)

       由名称和对应值组成的一个变量对象的属性被创建

       没有实参,属性值设为undefined

2.函数声明

       由名称和对应值(函数对象)组成一个变量对象的属性被创建

       如果变量对象以及存在相同名称的属性,则完全替换这个属性

3.变量声明

       有名称和对应值(undefined)组成的一个变量对象的属性被创建

       如果变量名称跟已经声明的形式参数或函数相同,则变量声明不会干扰已经存在的这类属性

 

举个例子

function foo(a){
  var b = 2;
  function c(){}
  var d = function(){};
  b = 3;
}

foo(1);

 在进入执行上下文后,这时候AO是:

AO = {
  arguments:{
    0:1,
    length:1
  },
  a:1,
  b:undefined,
  c:reference to funciton c(){},
  d:undefiend
}

 

代码执行

 

在代码执行阶段,会顺序执行代码,根据代码,修改变量对象的值

还是上面的例子,当代码执行完后,这时候的AO是:

AO = {
    arguments:{
       0:1,
       length:1
    },
    a:1,
    b:3,
    c:reference to funciton c(){},
    d:reference to FunctionExpresssion "d"
}

 

 到这里变量对象的创建过程就介绍完了,让我们简介的总结上述所说:

1.全局上下文的变量对象初始化是全局对象

2.函数上下文的变量对象初始化只包括Arguments对象

3.在进入执行上下文时会给变量对象添加形参、函数声明、变量声明等初始的属性值

4.在代码执行阶段,会再次修改变量对象的属性值

 

思考题

最后让我们看几个例子

1.第一题

function foo() {
    console.log(a);
    a = 1;
}

foo(); // ???

function bar() {
    a = 1;
    console.log(a);
}
bar(); // ???

 第一段会报错:Uncaught ReferenceError: a is not defined

 第二段会打印:1

这是因为函数中的“a”并没有通过var 关键字声明,所以不会被存放在AO中

第二段是从全局对象中找到a的值

如果第一段的声明变成var a = 1的话,结果就是undefined 

 

2.第二题

console.log(foo);

function foo(){
    console.log("foo");
}

var foo = 1;

 会打印函数,而不是undefined

这是因为在进入执行上下文时,首先会处理函数声明,其次会处理变量声明,如果变量名称跟已经声明的形参或函数相同,则变量声明不会干扰已经存在的这类属性(进入执行上下文阶段)

 

分享到:
评论

相关推荐

    理解Objective-C的变量以及面相对象的继承特性

    本文将深入探讨Objective-C中的变量和面向对象的继承特性。 首先,我们关注的是变量。在Objective-C中,变量的声明和访问有着独特的语法。Objective-C采用点语法(dot notation)来访问对象的属性,就像这样:`...

    Objective-C显示变量的值一

    这样,我们不仅实现了显示变量值的功能,还遵循了面向对象的设计原则,提高了代码的可读性和可维护性。 总结一下,Objective-C中显示变量的值通常涉及声明变量、对变量进行运算并使用`NSLog`函数或自定义方法来输出...

    Objective-C显示变量的值二

    本文将深入探讨如何在Objective-C中声明、赋值和显示变量,以及如何进行基本的数学运算,以实现标题中所提及的"Objective-C显示变量的值二"。我们将关注以下知识点: 1. **变量声明**: 在Objective-C中,变量是...

    03-03-04成员变量的实现.pdf

    理解成员变量的实现对于深入掌握Objective-C的内存管理和对象模型至关重要,这对于编写高效、稳定和健壮的iOS应用程序尤其重要。在实际开发中,合理使用成员变量和`@property`可以有效地提高代码的可读性和可维护性...

    面向对象程序设计(使用VS2005和C#)课件-2.变量与数据类型

    首先,让我们深入探讨变量。在编程中,变量是存储数据的容器。在C#中,声明一个变量需要指定它的数据类型,如int(整型)、double(双精度浮点型)或string(字符串)。变量的声明包括变量名和其数据类型,例如:`...

    3VS2010轻松学习C#-从零到深入-天轰穿.NET4趣味编程视频教程_第04讲_变量、常量数据类型

    在本节“3VS2010轻松学习C#-从零到深入-天轰穿.NET4趣味编程视频教程_第04讲_变量、常量数据类型”中,我们将深入探讨C#语言中的基本概念,包括变量和常量以及它们的数据类型。天轰穿老师通过VS2010集成开发环境,以...

    第一、二章---Java环境变量的配置[收集].pdf

    - 包括标识符、注释、变量、常量、基本数据类型、数据类型转换、运算符、选择语句(if和switch)、循环语句(for、while和do-while)、数组、字符串处理、面向对象概念(类、对象、继承、封装、多态)等。...

    PHP程序设计-3期(KC016) 拓展知识2-3 自定义变量.doc

    本文将深入探讨PHP中变量的结构、类型以及如何检测变量的类型和值,这些都是扩展开发时必须掌握的关键知识点。 首先,我们来了解一下PHP变量的内部实现。PHP的核心是用C语言编写的,其中变量的存储结构是由`zval`这...

    PHP面向对象之旅深入理解static变量与方法共11页

    本资料“PHP面向对象之旅深入理解static变量与方法”旨在帮助开发者深入理解PHP中的静态(static)变量和静态方法,这些都是OOP的重要组成部分。下面我们将详细探讨这两个概念。 1. 静态变量 静态变量是在类中定义...

    深入理解JavaScript系列(12) 变量对象(Variable Object)

    接下来,我将深入探讨与变量对象相关的知识点。 首先,需要明确变量对象(VO)与执行上下文(Execution Context)的关系。在JavaScript中,执行上下文是指当前JavaScript代码被解析和执行时所在环境的抽象概念,...

    类变量和实例变量.txt

    - **实例变量**:每个对象都有自己的实例变量副本,这些变量存储在堆内存中对应对象的实例数据区。 - **类变量**:所有对象共享同一份类变量,这些变量存储在方法区的静态数据区。 ##### 2. 访问权限 - **实例变量...

    PHP面向对象之旅深入理解static变量与方法

    下面我们将深入探讨`static`关键字的工作原理及其应用场景。 1. **静态变量** 静态变量是属于类本身而非类的实例的变量。这意味着所有类的实例共享同一份静态变量的副本,它们在内存中只存储一次。静态变量可以...

    变量对象概念

    本篇文章将深入探讨“变量对象”这一概念,帮助读者更好地理解JavaScript引擎的工作原理。 #### 二、变量对象概述 变量对象(Variable Object,简称VO)是指与特定执行上下文(Execution Context)相关联的一种特殊...

    深入理解变量作用域

    作用域链是一个对象列表,用于存储变量和函数声明。 - 当JavaScript引擎需要查找变量时,它会从当前作用域开始,沿着作用域链向上查找,直到找到相应的变量为止。 - 如果在当前作用域找不到变量,则继续在上一层...

    静态全局变量,静态局部变量,全局变量,局部变量

    ### C/C++中静态全局变量、静态局部变量、全局变量及局部变量的深入解析 #### 一、概念区分 在C/C++编程语言中,**静态全局变量**、**静态局部变量**、**全局变量**及**局部变量**是经常使用的几种变量类型,它们...

    Objective-C 2.0 with Cocoa Foundation--- 7,对象的初始化以及实例变量的作用域

    首先,让我们深入理解对象的初始化过程。在Objective-C中,初始化通常涉及`init`方法。每个类都有一个或多个初始化方法,它们负责为新创建的对象设置初始状态。默认情况下,当你调用`[[ClassName alloc] init]`时,...

    【视频】Excel精讲专题-VBA变量

    在"Excel精讲专题-VBA变量"这个视频教程中,我们将深入探讨VBA中的变量概念及其在实际应用中的重要性。 1. **VBA变量的基本概念** - 变量是存储数据的容器,它们在程序运行时可以改变其值。在VBA中,我们首先需要...

    java-学习-面对对象-匿名对象

    在“14-面向对象-匿名对象.avi”这个视频文件中,可能包含了更详细的讲解和示例,包括如何在实际项目中使用匿名对象,以及它们在多线程、事件处理等场景下的应用。观看这个视频可以更直观地理解匿名对象的概念及其...

Global site tag (gtag.js) - Google Analytics