高程(4):执行环境、作用域、上下文执行过程、垃圾收集、try...catch...

高程三 4.2、4.3

一、执行环境

1、全局执行环境是最外层的执行环境。

2、每个函数都有自己的执行环境,执行函数时,函数环境就会被推入一个当前环境栈中,执行完毕,栈将其环境弹出,把控制器返回给之前的执行环境。

二、作用域

1、每个执行环境,都对应一个自己的作用域。

2、每个执行环境,都能访问上一级的父级、父父级、...作用域,称为 “作用域链”

3、执行代码时,会按照标识符沿着作用域链一级一级向上查找。如果找不到,则会报错

  *标志符:执行时,使用到的变量或函数

三、上下文执行过程

进入执行环境后 代码执行前,编译器进行三个步骤:

1、查找并提升 “函数所有行参” 的声明(如果有行参的话)

2、查找并提升 “执行环境内部所有函数” 的声明

3、查找并提升 “执行环境内部所有变量” 的声明

上个例子:

function show(a, b) {
    //三步骤:

    /*
        // 1: 查找并提升 “函数所有行参” 的声明
        a = function() { console.log(‘aa‘); };
        b = undefined;
    */

    /*
        // 2: 查找并提升 “执行环境内部所有函数” 的声明
        // 此时 a的指向替换掉1中 a指向的函数
        a = function() { console.log(‘a222‘); }
    */
    /*
        // 3: 查找并提升 “执行环境内部所有变量” 的声明
        // 由于变量 优先级没有 函数高,所以此时a变量提升后无法替换上面的 a作为函数的指向
        b = undefined;
    */

    alert(a); // function a() { console.log(‘a222‘); }

    function a() { console.log(‘a222‘); }
    var a = 123;
    var b = 222;
    alert(a);  // 123
    alert(b);  // 222
}
show(function() { console.log(‘aa‘); });

注意:上面例子,第3步 由于变量声明提升的优先级,没有 函数声明提升的优先级高,所以 即使是发现了同名变量a,也无法替换到之前定义的a函数

可以参考:http://www.cnblogs.com/TomXu/archive/2012/01/16/2309728.html

四、垃圾收集

Javascript具有自动垃圾收集机制

1、原理:找出那些不需要再继续使用的变量,然后释放其占用的内存。

为此,垃圾收集器会按照固定的时间间隔(或代码执行中预定的收集时间)周期性地执行这一操作。

2、一般引擎采用两个策略:标记清除、引用计数

注意:虽然,js有自动垃圾收集机制,但是 为了性能优化,可以做到一点:

  a: 对象或函数或事件使用完后,重置为null,意味着切断变量与它此前引用的值之间的连接,下次垃圾收集器运行时,会删除这些值,并回收它们占用的内存。

五、try...catch(ex)...

try : 捕获异常语句

catch : 异常后续处理语句

function show() {
    var msg = ‘参数至少为一个‘;
    try {
        if (arguments.length == 0) {
            throw new Error(msg);
            // 异常后面的语句无法执行
            console.log(‘error...‘);
        }
        // 不影响if外面的执行
        console.log(‘go on...‘); //输出 go on...
    } catch (ex) {
        console.log(ex);
        throw new Error(msg);
    }
}

注意:

1、if内部抛出的异常只会影响,if内部后面的执行。而不会影响if外面的语句执行。

2、try...catch...常用在插件中。

时间: 2024-10-16 13:12:49

高程(4):执行环境、作用域、上下文执行过程、垃圾收集、try...catch...的相关文章

执行环境 作用域 作用域链 闭包的理解

1.首先 当一个变量或者函数被声明的时候 它的执行环境便被确认 , 执行环境定义了变量和函数有权访问的其他数据,决定了他们各自的行为, 而作用域就是变量和函数的可访问范围,控制着变量和函数的可见性与生命周期 每次进入一个新的执行环境,都会创建一个用于搜索变量和函数的作用域链.作用域链是函数被创建的作用域中对象的集合.作用域链可以保证对执行环境有权访问的所有变量和函数的有序访问. 作用域链的最前端始终是当前执行的代码所在环境的变量对象(如果该环境是函数,则将其活动对象作为变量对象),下一个变量对象

预备JS执行环境,预执行脚本

page.evaluateOnNewDocument(pageFunction, ...args) pageFunction <function|string> Function to be evaluated in browser context ...args <...Serializable> Arguments to pass to pageFunction returns: <Promise> Adds a function which would be in

*JS:执行环境、变量对象、活动对象和作用域链

var a=1; function b(x){ var c=2; console.log(x); } b(3); ·执行环境(execution context),也称为环境.执行上下文.上下文环境.执行上下文环境: 每次当控制器转到ECMAScript可执行代码的时候,即会进入到一个执行上下文.执行上下文(简称-EC)是ECMA-262标准里的一个抽象概念,用于同可执行代码(executable code)概念进行区分. 通俗的话来讲就是,JS中的函数运行不能仅仅看函数内部有哪些变量,再简单的

执行环境、变量对象和作用域链

执行环境又称执行上下文,英文缩写是EC(Execution Context),每当执行流转到可执行代码时,即会进入一个执行环境.在JavaScript中,执行环境分三种: 全局执行环境 — 这个是最外围的代码执行环境,一旦代码被载入,引擎最先进入的就是这个环境.在浏览器中,全局环境就是window对象,一次所有全局属性和函数都是作为window对象的属性和方法创建的.全局执行环境直到应用程序退出时才会被销毁. 函数执行环境 — 当执行一个函数时,JavaScript引擎进入执行环境.某个执行环境

执行环境,作用域

在javascript的学习中,执行环境.作用域是2个非常非常重要和基本的概念,理解了这2个概念对于javsacript中很多脚本的运行结果就能明白其中的道理了,比如搞清作用域和执行环境对于闭包的理解至关重要. 一.执行环境(exection context,也有称之为执行上下文) 所有 JavaScript 代码都是在一个执行环境中被执行的.执行环境是一个概念,一种机制,用来完成JavaScript运行时在作用域.生存期等方面的处理,它定义了变量或函数是否有权访问其他数据,决定各自行为. 在j

Javascript执行环境、作用域链

一.执行环境 执行环境(也叫做执行上下文,Execution Context)是Javascript中最为重要的一个概念.执行环境定义了变量或函数有权访问其他数据,决定了它们各自的行为.每个执行环境都有一个与之关联的变量对象,执行环境中定义的所有变量和函数都保存在这个对象中.虽然我们编写的代码无法访问这个对象,但解析器在处理时会在后台使用它. 全局执行环境是最外围的一个执行环境.根据ECMAScript实现所在的宿主环境不同,表示执行环境的对象也不一样.在web浏览器中,全局执行环境被认为是wi

javascript 作用域链及闭包,AO,VO,执行环境

下面的文章内容会根据理解程度不断修正. js变量作用域: 定义:变量在它申明的函数体以及函数体内嵌套的任意函数体内有定义. function AA(){ var bb='我是AA内部变量'; function TT(){ alert(bb); } alert(bb); TT(); } AA(); 如上图,两次弹出的都是“我是AA内部变量”. JS的变量作用域是函数级的,也就是在AA内部申明的变量,在AA内部任意位置,包括它嵌套的函数内也是有定义的. 在函数AA外面,bb就是没有定义的.当然如果去

JavaScript执行环境及作用域

执行环境(executin context)是JS中最为重要的一个概念.执行环境定义了变量或函数有权访问的其他数据决定了它们各自的行为.每个执行环境都有一个与之关联的变量对象(variable object),环境中定义的所有变量和函数都保存在这个对象中.虽然我们编写的代码无法访问这个对象 ,但解析器在处理数据时会在后台使用它. 全局执行环境是最外围的一个执行环境.根据JS实现的宿主环境不同,表示执行环境的对象也不一样.在Web浏览器中,全局执行环境被认为是Window对象,因此所有全局变量和函

Javascript 函数及其执行环境和作用域

函数在javascript中可以说是一等公民,也是最有意思的事情,javascript函数其实也是一个对象,是Function类型的实例.因此声明一个函数首先可以使用 Function构造函数: var saySomething = new Function("something","console.log(something)"); saySomething("hello world!"); // 输出hello world! Function

JS复习—执行环境及作用域

执行环境及作用域 一.定义 (1)执行环境:执行环境定义了变量或函数有权访问其他数据,决定了它们各自的行为. (2)作用域链:保证对执行环境有权访问的所有变量和函数的有序访问.作用域链本质是一个指向变量对象的指针列表,它只是引用但不实际包含变量对象 (3)变量对象:环境中定义的所有变量和函数都保存在这个对象中 (4)活动对象:如果当前的环境是函数,则这个变量对象是活动对象 (5)作用域:程序代码中定义这个变量的区域 二.标示符的搜索过程 当某个函数被调用时,会创建一个执行环境及相应的作用域链.然