javascript - js函数的父级变量如果未被内部函数引用,是否会保存在作用域链中?
本文介绍了javascript - js函数的父级变量如果未被内部函数引用,是否会保存在作用域链中?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
window.onload = function(){ var a = 1; function test() { var b = new Array(10000); var c = new Array(10000); // 1.创建函数inner时会创建inner的作用域链, 此时inner的作用域链中是不是保存a、b、c 三个变量?如果不是那是保存的什么? function inner(){ console.log(b); } // 2.执行函数a时,会创建a的执行环境,其中包含作用域链,但是通过chrome控制台观察发现,断点停留在inner内部时,父级闭包作用域中只有引用的变量b,而没有变量c,是因为作用域链中只保存引用的变量吗? // 3.未被引用的变量c是否被标记回收? inner(); } test(); };
问题描述请看代码中的注释,有可能描述错误,请指正。请帮忙回答这三个问题。附图
解决方案
创建inner函数时,会复制一份外部函数的作用域链,赋值给inner函数的内部属性[[scope]],当运行inner时才会创建inner函数的作用域链,并且将inner函数的this,arguments,参数,声明的变量推入到作用域链的顶端;
好像控制台只会显示用过的作用域链上的变量,但是其他的同样会保存
当你运行inner时,test都还没有运行完,自然c不会被回收
这篇关于javascript - js函数的父级变量如果未被内部函数引用,是否会保存在作用域链中?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文