闭包执行JavaScript中的闭包

查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记录吧!

    最近在应用JavaScript的时候遇到了一种很特别的格式,一个函数却返回另一个函数。这就是Javascript中的闭包。

    闭包的两个特色:

    1、作为一个函数变量的一个引用 - 当函数返回时,其处于激活状态。
2、一个闭包就是当一个函数返回时,一个没有释放资源的栈区。

其实下面两点可以合成一点,就是闭包函数返回时,该函数内部变量处于激活状态,函数所在栈区仍然保存.我们所熟知的主流语言,像C,java等,在函数内部只要执行了return,函数就会返回结果,然后内存中删除该函数所在的区域.生命周期也就停止了.一般的js函数也是这样.

    但是有闭包特性的js函数有点特殊.就例子来讲:

function a(){
 var i=0;
 function b(){
 alert(++i);
 }
 return b;
}
var c = a();
c();

    这是个标准的闭包.在函数a中定义了函数b,a又return了b的值.这些可以先不管.

    
var c = a();
c();
这两句执行很主要.
在var c = a();这行里,执行了a函数,那么肯定a经过了return.按照主流语言的函数特性,现在c的值就是a的返回值.
第二行c()的执行现实执行的就是b函数.最后不管执行的是谁,会弹出一个值为0的窗口,到此为止,所有的生命周期按理论来讲就算全体结束了.
可是,如果我们再多执行一行.
var c = a();
c();
c();
第一次弹出0,第二次执行却弹出了1.也就是说,第一次c()后,a中的i仍然保存.天然a在内存的栈区仍然保存.a是return过了,但是,a及内部值却仍然存在,这就是闭包.

总结下,
1,闭包外层是个函数.
2,闭包内部都有函数.
3,闭包会return内部函数.
4,闭包返回的函数内部不能有return.(因为这样就真的结束了)

    每日一道理
一个安静的夜晚,我独自一人,有些空虚,有些凄凉。坐在星空下,抬头仰望美丽天空,感觉真实却由虚幻,闪闪烁烁,似乎看来还有些跳动。美的一切总在瞬间,如同“海市蜃楼”般,也只是刹那间的一闪而过,当天空变得明亮,而这星星也早已一同退去……

    5,执行闭包后,闭包内部变量会存在,而闭包内部函数的内部变量不会存在.

    

    闭包的应用场景
1、保护函数内的变量安全。以最开始的例子为例,函数a中i只有函数b才能访问,而没法通过其他途径访问到,因此保护了i的安全性。
2、在内存中维持一个变量。仍然如前例,由于闭包,函数a中i的始终存在于内存中,因此每次执行c(),都会给i自加1。

我们会天然的想到java或是c++的类.虽然JS没有类的观点,但是有了类的相似

    应用闭包的注意点
1)由于闭包会使得函数中的变量都被保存在内存中,内存消费很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能致使内存泄露。解决方法是,在退出函数之前,将不应用的局部变量全体删除。

    2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)应用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随意改变父函数内部变量的值。

文章结束给大家分享下程序员的一些笑话语录: 3G普不普及现在已经不是看终端了,而是看应用,有好的,便宜实用的应用,花1000多买个能用的智能手机应该不是什么难事。反过来说,你200元拿一个智能手机,没有好的应用,看个电影要几十元,也是没人用3G。

原文地址:https://www.cnblogs.com/xinyuyuanm/p/3091819.html