zoukankan      html  css  js  c++  java
  • Javascript 闭包的理解

    示例1:

    复制代码
    function makeCounter() {
        var i = 0;
        console.log( ++i );
    }
    
    var counter = makeCounter(); // 输出: 1
    counter();  //TypeError: undefined is not a function
    counter();  //TypeError: undefined is not a function
    复制代码

    这个例子中,声明了一个makeCounter函数,发现 var counter = makeCounter(); 输出了一个结果: 1   这是因为实际上  赋值号的右边 makeCounter() 就把函数执行了一遍,但没有返回值,所以 counter 被赋予了 undefined ,接下来的两次调用返回错误 TypeError: undefined is not a function

    再来看修改后的代码:

    示例2:

    复制代码
    function makeCounter() {
        var i = 0;
        return function() {
            console.log( ++i );
        };
    }
    
    var counter = makeCounter;  //无输出
    counter(); // 无输出
    counter(); // 无输出
    
    var counter2 = counter();  //无输出
    counter2(); // 输出: 1
    counter2(); // 输出: 2
    
    var counter3 = makeCounter();  //无输出
    counter3(); // 输出: 1
    counter3(); // 输出: 2
    
    console.log(i);
    // ReferenceError: i is not defined
    复制代码

    这次 makeCounter函数返回值是一个函数,这里其实是一个闭包,根据javascript高级程序设计,闭包是指有权访问另一个函数作用域中的变量的函数。 根据 MDN:

    Closures are functions that refer to independent (free) variables.

    In other words, the function defined in the closure 'remembers' the environment in which it was created.

    指通常我们把像这样在一个函数内部再创建一个函数就是创建闭包的最常见方式。

    闭包中的函数能够“记住”创建它的外层环境的活动对象,makeCount函数执行之后,其活动对象并不会被销毁,因为闭包内的函数的作用域链仍然在引用这个活动对象,因此仍然保留在内存中。从垃圾回收角度看就是外部执行环境的活动对象不会被当做垃圾回收。

    如上面代码所示,值得注意的是每次调用makeCount函数,即每次返回闭包时虽然内部函数体是一样的,但是每次执行一次,它执行环境的活动对象都是独立的,互相并不关联,请见 count2() 和count3() 的输出。

    可以说 javascript中的函数都在闭包中,因为每个函数都能够访问到函数体之外的全局执行环境。

  • 相关阅读:
    Go语言new( )函数
    Go语言讲解深拷贝与浅拷贝
    (转)使用kubectl访问Kubernetes集群时的身份验证和授权
    执行kubectl命令时报错 error: You must be logged in to the server (Unauthorized)
    报错 cannot allocate memory 或者 no space left on device ,修复K8S内存泄露问题
    linux之apt-get命令(转)
    GSensor 碰撞检测方法与实现
    uboot流程(转)
    linux 环境搭建
    333开发记录
  • 原文地址:https://www.cnblogs.com/jymz/p/4027302.html
Copyright © 2011-2022 走看看