本文实例讲述了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);
再看看内存分析图:
由上图可知我们无法直接操作存储在堆中的数据,但是我们可以通过栈中的引用来操作对象。那么为什么要分开呢?不都是存储在内存中吗?
栈的优势就是存取速度比堆要快,仅次于直接位于CPU中的寄存器,但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,垃圾收集器会自动地收走这些不再使用的数据,但是缺点是由于在运行时动态分配内存,所以存取速度较慢。
所以相对于简单数据类型而言,他们占用内存比较小,如果放在堆中,查找会浪费很多时间,而把堆中的数据放入栈中也会影响栈的效率,比如对象和数组是可以无限拓展的,正好放在可以动态分配大小的堆中。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript面向对象入门教程》、《JavaScript错误与调试技巧总结》,《JavaScript数据结构与算法技巧总结》,《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。