标签:点击 ++ class 指针 length 点击事件 lin log 其他
一般情况下,函数执行形成一个私有的作用域,当执行完成后就销毁了->节省内存空间
function fn(){ var i=10; return function(n){ console.log(n+i++); } } fn()(15);//->先执行fn,有一个私有的变量i=10,返回一个堆内存地址 xxxfff111,我们发现这个地址还用到了一次,那么当前的这个fn形成私有作用域(A)就不能立即销毁了,xxxfff111(15)->输出25,A中的i变为11;当xxxfff111执行完了,发现这个地址没用了,浏览器就把A、xxxfff111都释放了 fn()(20);//->在执行fn的时候一切都从新开始了,和上面的步骤是一样的->输出30
function fn(){ var i=10; return function(n){ console.log(n+i++); } } var f=fn();//->fn执行形成一个私有的作用域A,A中有一个私有的变量i=10,A中返回一个地址xxxfff11,被外面的f占用了,那么当前的A就不能销毁了 f(15);//->输出25,让A中的i=11 f(20);//->输出31,让A中的i=12 ...
当我们知道f用完的时候,为了优化性能,我们让f=null,这样的话A中的xxxfff111没人占用了,浏览器会把A和xxxfff111都释放了
//每一次循环都执行自执行函数形成一个私有的作用域(循环三次就有三个作用域,每一个作用域中都有一个i,第一个存储的是0,第二个存数的是1..),在每一个私有的作用域中都把里面的函数绑定给了外面元素的点击事件,这样的话每一次形成的作用域都不销毁了(三个不销毁的作用域)
var oLis=document.getElementsByTagName("li"); for(var i=0;i<oLis.length;i++){ ~function(i){ oLis[i].onclick=function(){ tabChange(i); } }(i); }
function move(tar){ <js code> //window.setTimeout(move,10); ->第二次执行move的时候我们没有给它传值(这样写不行) window.setTimeout(function(){ move(tar); },10);//->这样写实现了,但是每一次执行定时器都会形成一个私有的所用域(匿名函数形成的)A,在A中使用了上级作用域中的tar的值,而且执行了move又形成了一个小的作用域(而在小的作用域中会使用tar的值),这样每一次定时器形成的A都不能销毁了 } move(100);//->第一次这样执行传递100
//解决办法:
function move(tar){ ~function _move(){ <js code> window.setTimeout(_move,10); }(); } move(100);//->第一次这样执行传递100
[谷歌浏览器]
我们开辟一个内存,可能或有一些其他的变量等占用了这个内存,谷歌浏览器都会间隔一段时间看这个内存还有没有被占用,如果发现有没有被占用的内存了,就自己帮我们回收了(内存释放)
[火狐和IE]
我们开个内存,当我们引用了它,就在内存中记录一个数,增加一个引用浏览器就把这个数+1,减少一个引用,浏览器就把这个数-1...当减到零的时候浏览器就把这个内存释放了;但是有些情况下(尤其是IE)记着记着就弄乱了,内存就不能释放了-->浏览器的内存泄露
var obj={};
我们养成一个好的习惯,当我们obj这个对象使用完成了,我们手动的obj=null (null空对象指针),浏览器会自己把刚才的堆内存释放掉
标签:点击 ++ class 指针 length 点击事件 lin log 其他
原文地址:http://www.cnblogs.com/Scar007/p/7722963.html