zoukankan      html  css  js  c++  java
  • 闭包函数详解

    从技术的角度讲,所有的JavaScript函数都是闭包:它们都是对象,它们都关联到作用域链。当函数可以记住并访问所在的词法作用域时,就产生了闭包,即使函数是在当前词法作用域之外执行。
    闭包的作用
    闭包的应用比较典型是定义模块,我们将操作函数暴露给外部,而细节隐藏在模块内部。

    var name = 'iceman';
    function fn2() {
    console.log(name);
    }
    return fn2;
    }
    var fn3 = fn1();
    fn3();
    

    这样就清晰地展示了闭包:

    fn2的词法作用域能访问fn1的作用域

    将fn2当做一个值返回

    fn1执行后,将fn2的引用赋值给fn3

    执行fn3,输出了变量name

    我们知道通过引用的关系,fn3就是fn2函数本身。执行fn3能正常输出name,这不就是fn2能记住并访问它所在的词法作用域,而且fn2函数的运行还是在当前词法作用域之外了。
    正常来说,当fn1函数执行完毕之后,其作用域是会被销毁的,然后垃圾回收器会释放那段内存空间。而闭包却很神奇的将fn1的作用域存活了下来,fn2依然持有该作用域的引用,这个引用就是闭包。

    总结:一个函数在内部无法被调用,利用外部的函数返回值return让内部函数可以被调用。
    关于递归函数的详细理解
    递归算法是一种看似简单,但逻辑性比较复杂的算法,
    一般用if需要设置好递归函数的结束条件,不然容易陷入死循环。

    function f(n) {
        if (n <= 1){
            // console.log(1111);
            return 1;
        }else {
            // console.log(n * f(n-1));
            return n * f(n-1);
        }
    }
    
    console.log(f(10)); // 3628800
    

    这样就清晰地展示了递归函数的运算:
    递归的特点总结:

    优点,自调用,就是在函数里面调用自己.
    缺点,就是消耗大量内存

  • 相关阅读:
    解决:只有 DBA 才能导入由其他 DBA 导出的文件
    查找—顺序查找
    软件测试,想说爱你不容易
    Oracle常用SQL
    排序—直接插入排序
    排序—归并排序
    排序—快速排序
    排序—选择排序
    查找—折半查找
    排序—堆排序
  • 原文地址:https://www.cnblogs.com/wangjiahui/p/10849846.html
Copyright © 2011-2022 走看看