闭包与递归函数的区别

2018/02/28 23:41
阅读数 0

 

# 闭包与递归函数的区别


闭包函数

闭包是指有权访问另一个函数作用域中的变量的函数。这个是官方的解释。闭包其实也是函数,可是不同于其他的函数。它是在函数里面嵌套一个函数的函数,其内部函数引用外部函数的变量、参数。

下面举个例子来理解:

function outFunction(objName){
  return function( object 1, object 2){
   var value1 = object1[objName];
  var value2 = object2[objName];
  if( value 1 < value 2){
  return - 1;
  } else if( value 1 > value 2){
    return 1;
  } else{
  return 0;
    }
  };
}
var compare = outFunction( "name");
var result = compare({name: "Nicholas"},{name: "Greg"});

var value1 = object1[objName];这行代码访问了外部函数中的变量objName。内部函数可以访问外部函数的变量是作用域链的问题。

总结一下,形成闭包需要满足:1)在函数的内部嵌套一个函数;2)内部函数引用了外部函数的变量、参数。


递归函数

递归函数是在一个函数通过函数名字调用自身的函数。
例如:

function factorial( num){
   if ( num <= 1) {
   return 1;
  } else{
    return num * factorial(num - 1);
    }
  }
console. log( factorial( 4)); // 24

 

闭包与递归的区别:
相同点:1)都是函数
    2)在函数的内部都会调用函数

不同点: 1)闭包函数调用的内部函数需要引用外部函数的变量、参数;递归函数是自己调用自己,不需要引用变量、参数
     2)闭包函数调用一次结束调用,递归函数在满足递归条件时需要多次调用
     3)闭包函数会比其他函数更占内存

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部