javascript内存分配原理实例分析

  

本文实例讲述了javascript内存分配原理。分享给大家供大家参考,具体如下:

  

JavaScript中的变量分为两种,原始值和引用值,比如未定义,null,号码,字符串,布尔类型所表示的值,即对象,函数,数组等。

  

…   

存储在栈中的值是一个指针,指向存储在堆中的实际对象。

  

我们来看一段代码:

        函数的人(id、姓名、年龄){   这一点。id=id;   this.name=名称;   这一点。年龄=年龄;   }   var num=10;   var波尔=true;   var str=癮bc”;   var obj=新对象();   var arr=[' a ', ' b ', ' c ');   var=new人(100年,“jxl”, 22);      

再看看内存分析图:

  

 javascript内存分配原理实例分析

  

由上图可知我们无法直接操作存储在堆中的数据,但是我们可以通过栈中的引用来操作对象。那么为什么要分开呢?不都是存储在内存中吗?

  

栈的优势就是存取速度比堆要快,仅次于直接位于CPU中的寄存器,但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,垃圾收集器会自动地收走这些不再使用的数据,但是缺点是由于在运行时动态分配内存,所以存取速度较慢。

  

所以相对于简单数据类型而言,他们占用内存比较小,如果放在堆中,查找会浪费很多时间,而把堆中的数据放入栈中也会影响栈的效率,比如对象和数组是可以无限拓展的,正好放在可以动态分配大小的堆中。

  

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript面向对象入门教程》、《JavaScript错误与调试技巧总结》,《JavaScript数据结构与算法技巧总结》,《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

  

希望本文所述对大家JavaScript程序设计有所帮助。

javascript内存分配原理实例分析