最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:31:37
文档

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

JavaScript数据类型的存储方法详解:一个很基础的知识点,JavaScript中基本数据类型和引用数据类型是如何存储的。 由于自己是野生程序员,在刚开始学习程序设计的时候没有在意内存这些基础知识,导致后来在提到什么什么是存在栈中的,栈中只是存了一个引用这样的话时总是一脸懵逼。 后来
推荐度:
导读JavaScript数据类型的存储方法详解:一个很基础的知识点,JavaScript中基本数据类型和引用数据类型是如何存储的。 由于自己是野生程序员,在刚开始学习程序设计的时候没有在意内存这些基础知识,导致后来在提到什么什么是存在栈中的,栈中只是存了一个引用这样的话时总是一脸懵逼。 后来


一个很基础的知识点,JavaScript中基本数据类型和引用数据类型是如何存储的。

由于自己是野生程序员,在刚开始学习程序设计的时候没有在意内存这些基础知识,导致后来在提到“什么什么是存在栈中的,栈中只是存了一个引用”这样的话时总是一脸懵逼。

后来渐渐的了解了一些内存的知识,这部分还是非常有必要了解的。

基本数据结构

栈,只允许在一段进行插入或者删除操作的线性表,是一种先进后出的数据结构。

堆是基于散列算法的数据结构。

队列

队列是一种先进先出(FIFO)的数据结构。

JavaScript中数据类型的存储

JavaScript中将数据类型分为基本数据类型和引用数据类型,它们其中有一个区别就是存储的位置不同。

基本数据类型

我们都知道JavaScript中的基本数据类型有:

  • String
  • Number
  • Boolean
  • Undefined
  • Null
  • Symbol(暂时不管)
  • 基本数据类型都是一些简单的数据段,它们是存储在栈内存中。

    引用数据类型

    JavaScript中的引用数据类型有:

  • Array
  • Object
  • 引用数据类型是保存在堆内存中的,然后再栈内存中保存一个对堆内存中实际对象的引用。所以,JavaScript中对引用数据类型的操作都是操作对象的引用而不是实际的对象。

    可以理解为,栈内存中保存了一个地址,这个地址和堆内存中的实际值是相关的。

    图解

    现在,我们声明几个变量试试:

    var name="axuebin";
    var age=25;
    var job;
    var arr=[1,2,3];
    var obj={age:25};

    可以通过下图来表示数据类型在内存中的存储情况:

    此时 name , age , job 三种基本数据类型是直接存在栈内存中的,而 arr , obj 在栈内存中只是存了一个地址来表示对堆内存中的引用。

    复制

    基本数据类型

    对于基本数据类型,如果进行复制,系统会自动为新的变量在栈内存中分配一个新值,很容易理解。

    引用数据类型

    如果对于数组、对象这样的引用数据类型而言,复制的时候就会有所区别了:

    系统也会自动为新的变量在栈内存中分配一个值,但这个值仅仅是一个地址。也就是说,复制出来的变量和原有的变量具有相同的地址值,指向堆内存中的同一个对象。

    如果所示,执行了 var objCopy=obj 之后, obj 和 objCopy 具有相同的地址值,执行堆内存中的同一个实际对象。

    这有什么不同呢?

    当我修改 obj 或 objCopy 时,都会引起另一个变量的改变。

    为什么?

    为什么基础数据类型存在栈中,而引用数据类型存在堆中呢?

    1. 堆比栈大,栈比对速度快。
    2. 基础数据类型比较稳定,而且相对来说占用的内存小。
    3. 引用数据类型大小是动态的,而且是无限的。
    4. 堆内存是无序存储,可以根据引用直接获取。

    总结

    以上所述是小编给大家介绍的JavaScript数据类型的存储方法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    文档

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

    JavaScript数据类型的存储方法详解:一个很基础的知识点,JavaScript中基本数据类型和引用数据类型是如何存储的。 由于自己是野生程序员,在刚开始学习程序设计的时候没有在意内存这些基础知识,导致后来在提到什么什么是存在栈中的,栈中只是存了一个引用这样的话时总是一脸懵逼。 后来
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top