递归和闭包

闭包

1.定义: 函数内部有函数(函数嵌套),内部函数操作外部函数的局部变量,且外层函数的引用被赋值给变量,通过变量访问内层函数匿名函数.

2.作用:1.可以读取函数内部的变量,2.让这些变量的值始终保持在内存中,不会在f1调用后被自动清除。

3.应用场景:循环绑定事件 .主要用于封装jQuery插件,开发中用的少.

4.优点:避免变量污染.

5.缺点:闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

递归:

定义:递归函数是在一个函数通过函数名字调用自身的函数(函数自调用)。 

应用场景:维护table列表组建,做了一个表头筛选的功能。其中就需要获取筛选项,当有多个筛选项数组都需要从后台获取的时候,就需要循环数组发送ajax请求,但是由于ajax是异步的。多个请求就无法正常处理返回。 
所以使用递归,在ajax的回调中重新调用他:

优点:

简洁,在遍历算法中,递归的实现明显要比循环简单得多

缺点:

1.存在时间和空间的消耗,

2.调用栈可能会溢出.影响性能.

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

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

猜你喜欢

转载自www.cnblogs.com/mlw1814011067/p/11648290.html