我在哪里可以找到有关实现闭包的详细信息(如JavaScript或Scheme)?

我对编译器理论以及传统的过程语言和面向对象语言(如C,Pascal和 Java)的运行时环境非常熟悉.我希望详细了解如何实现像 JavaScript这样的语言的运行时结构,特别是与闭包相关:如何管理存储,何时分配闭包,如何决定何时释放闭包存储.如果没有挖掘V8或Rhino的源代码,你能指出我可以提供这种描述的论文或书籍或教程吗?

谢谢.

解决方法

它相当简单,它是嵌套命名空间的一个克隆,所以它与编译器理论相反,它是运行时分配的命名空间,用于解析符号查找,与编译语言相比,它将符号编译成静态偏移.

但基本上所有这意味着符号查找针对名称间的链接列表发生,从本地名称空间开始,到封闭的名称空间(闭包).

在javascript中,命名空间只是一个对象,具有引用该命名空间的任何打开函数的引用计数

例如

var links = //a list of links identified set somehwere else
for(var i = 0,l = 3; l--; i++){
   (function(n){
      links[i].onclick = function(){ alert(n); }
   })(i)
}

在上面的代码中,links [i]用于访问数组,但是在点击链接时,我将增加,从而与链接数量不同.所以n是在父命名空间中设置的,这样当它触发alert(n)时就会准确.

global
|
|\
| +-- function(n=0) <- link0.onclick = function()
|\
| +-- function(n=1) <- link1.onclick = function()
 \
  +-- function(n=2) <- link2.onclick = function()

这分为3个堆栈帧,每次i迭代一个.并且hte’onclick =’表达式右侧的函数一个对堆栈框的引用,因为它是词法父级,它启动它的符号查找.

他们最终都会看到相同的命名空间,因为他们共享一个祖父母.

一些链接

https://developer.mozilla.org/en/a_re-introduction_to_javascript

这个最小的方案比v8源更容易阅读:

http://code.google.com/p/chibi-scheme/

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...