function test(){
var a=10;
return function(){
a++;
console.log(a)
}
}
test()(); //两次打印的之都是11
test()();
从打印的值来看,当局部变量 a 在函数运行结束后,就被回收掉了,运算的值也没保存
function test1(){
var b = 0;
return function(){
b ++;
console.log(b);
}
}
var d = test1();
d();//第一次打印的值 =1
d();//第一次打印的值 =2
第二段代码运算结束,可以看出 函数中的变量 b 并没有被系统回收掉,而将运算的值给保存了下来
因此;js中局部变量 在没有被外部引用的情况下,当所在函数运行结束后,就被系统当做无用变量给回收了;
而当局部变量所在的函数被外部引用时,此变量不会被回收,并且会保存运算的值,只要外部不为null,则一直保存
js中的回收机制
最新推荐文章于 2024-06-18 10:15:00 发布