源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

JavaScript数据类型的存储方法详解

  • 时间:2020-03-10 07:43 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:JavaScript数据类型的存储方法详解
一个很基础的知识点,JavaScript中基本数据类型和引用数据类型是如何存储的。 由于自己是野生程序员,在刚开始学习程序设计的时候没有在意内存这些基础知识,导致后来在提到“什么什么是存在栈中的,栈中只是存了一个引用”这样的话时总是一脸懵逼。。 后来渐渐的了解了一些内存的知识,这部分还是非常有必要了解的。 [b]基本数据结构[/b] [b]栈[/b] 栈,只允许在一段进行插入或者删除操作的线性表,是一种先进后出的数据结构。 [b]堆[/b] 堆是基于散列算法的数据结构。 [b]队列[/b] 队列是一种先进先出(FIFO)的数据结构。 [b]JavaScript中数据类型的存储[/b] JavaScript中将数据类型分为基本数据类型和引用数据类型,它们其中有一个区别就是存储的位置不同。 [b]基本数据类型[/b] 我们都知道JavaScript中的基本数据类型有: [list] [*]String[/*] [*]Number[/*] [*]Boolean[/*] [*]Undefined[/*] [*]Null[/*] [*]Symbol(暂时不管)[/*] [/list] 基本数据类型都是一些简单的数据段,它们是存储在栈内存中。 [b]引用数据类型[/b] JavaScript中的引用数据类型有: [list] [*]Array[/*] [*]Object[/*] [/list] 引用数据类型是保存在堆内存中的,然后再栈内存中保存一个对堆内存中实际对象的引用。所以,JavaScript中对引用数据类型的操作都是操作对象的引用而不是实际的对象。 可以理解为,栈内存中保存了一个地址,这个地址和堆内存中的实际值是相关的。 [b]图解[/b] 现在,我们声明几个变量试试:
var name="axuebin";
var age=25;
var job;
var arr=[1,2,3];
var obj={age:25};
可以通过下图来表示数据类型在内存中的存储情况: [img]http://files.jb51.net/file_images/article/201708/201708250850131.png[/img] 此时 name , age , job 三种基本数据类型是直接存在栈内存中的,而 arr , obj 在栈内存中只是存了一个地址来表示对堆内存中的引用。 [b]复制[/b] [b]基本数据类型[/b] 对于基本数据类型,如果进行复制,系统会自动为新的变量在栈内存中分配一个新值,很容易理解。 [b]引用数据类型[/b] 如果对于数组、对象这样的引用数据类型而言,复制的时候就会有所区别了: 系统也会自动为新的变量在栈内存中分配一个值,但这个值仅仅是一个地址。也就是说,复制出来的变量和原有的变量具有相同的地址值,指向堆内存中的同一个对象。 [img]http://files.jb51.net/file_images/article/201708/201708250850132.png[/img] 如果所示,执行了 [code]var objCopy=obj [/code]之后, obj 和 objCopy 具有相同的地址值,执行堆内存中的同一个实际对象。 这有什么不同呢? 当我修改 obj 或 objCopy 时,都会引起另一个变量的改变。 [b]为什么?[/b] 为什么基础数据类型存在栈中,而引用数据类型存在堆中呢? [list=1] [*]堆比栈大,栈比对速度快。[/*] [*]基础数据类型比较稳定,而且相对来说占用的内存小。[/*] [*]引用数据类型大小是动态的,而且是无限的。[/*] [*]堆内存是无序存储,可以根据引用直接获取。[/*] [/list] [b]总结[/b] 以上所述是小编给大家介绍的JavaScript数据类型的存储方法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部