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


Posted in Javascript onAugust 25, 2017

一个很基础的知识点,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};

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

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

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

复制

基本数据类型

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

引用数据类型

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

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

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

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

这有什么不同呢?

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

为什么?

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

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

总结

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

Javascript 相关文章推荐
使两个iframe的高度与内容自适应,且相等
Nov 20 Javascript
js自定义方法通过隐藏iframe实现文件下载
Feb 21 Javascript
JavaScript设计模式之建造者模式介绍
Dec 28 Javascript
jQuery插件EasyUI获取当前Tab中iframe窗体对象的方法
Aug 05 Javascript
浅谈Node.js:理解stream
Dec 08 Javascript
jQuery Ajax实现跨域请求
Jan 21 Javascript
npm scripts 使用指南详解
Oct 08 Javascript
JQuery样式操作、click事件以及索引值-选项卡应用示例
May 14 jQuery
IE11下处理Promise及Vue的单项数据流问题
Jul 24 Javascript
jQuery实现弹出层效果
Dec 10 jQuery
JS 逻辑判断不要只知道用 if-else 和 switch条件判断(小技巧)
May 27 Javascript
Nuxt的路由配置和参数传递方式
Nov 06 Javascript
使用JQ完成表格隔行换色的简单实例
Aug 25 #Javascript
Vue.js实现网格列表布局转换方法
Aug 25 #Javascript
Angular2 组件间通过@Input @Output通讯示例
Aug 24 #Javascript
Angular2 组件交互实例详解
Aug 24 #Javascript
使用jQuery实现页面定时弹出广告效果
Aug 24 #jQuery
探究react-native 源码的图片缓存问题
Aug 24 #Javascript
详解vue.js之绑定class和style的示例代码
Aug 24 #Javascript
You might like
php获取文件大小的方法
2014/02/26 PHP
PHP常用文件操作函数和简单实例分析
2016/06/03 PHP
php求今天、昨天、明天时间戳的简单实现方法
2016/07/28 PHP
完美解决php 导出excle的.csv格式的数据时乱码问题
2017/02/18 PHP
jQuery温习篇 强大的JQuery选择器
2010/04/24 Javascript
捕获键盘事件(且兼容各浏览器)
2013/07/03 Javascript
jquery mobile实现拨打电话功能的几种方法
2013/08/05 Javascript
JQuery中$.ajax()方法参数详解及应用
2013/12/12 Javascript
基于jQuery实现网页进度显示插件
2015/03/04 Javascript
jquery实现滑动特效代码
2015/08/10 Javascript
利用Node.js制作爬取大众点评的爬虫
2016/09/22 Javascript
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
2016/12/14 Javascript
js前端日历控件(悬浮、拖拽、自由变形)
2017/03/02 Javascript
Vue项目中引入外部文件的方法(css、js、less)
2017/07/24 Javascript
详解webpack的配置文件entry与output
2017/08/21 Javascript
JS使用对象的defineProperty进行变量监控操作示例
2019/02/02 Javascript
ES6中Set和Map数据结构,Map与其它数据结构互相转换操作实例详解
2019/02/28 Javascript
解决vue的touchStart事件及click事件冲突问题
2020/07/21 Javascript
js实现缓动动画
2020/11/25 Javascript
vue-calendar-component 封装多日期选择组件的实例代码
2020/12/04 Vue.js
[36:45]TNC vs VGJ.S 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
详解Python中with语句的用法
2015/04/15 Python
Django小白教程之Django用户注册与登录
2016/04/22 Python
浅析python继承与多重继承
2018/09/13 Python
python scipy求解非线性方程的方法(fsolve/root)
2018/11/12 Python
Python 实现顺序高斯消元法示例
2019/12/09 Python
HTML5新增的8类INPUT输入类型介绍
2015/07/06 HTML / CSS
Myprotein法国官网:欧洲第一运动营养品牌
2019/03/26 全球购物
维德科技C#面试题笔试题
2015/12/09 面试题
大学生个人求职信范文
2013/09/21 职场文书
《争吵》教学反思
2014/02/15 职场文书
论文诚信承诺书
2014/05/23 职场文书
汉语言文学毕业求职信
2014/07/17 职场文书
军事博物馆观后感
2015/06/05 职场文书
贷款工资证明范本
2015/06/12 职场文书
写作指导:怎么书写竞聘演讲稿?
2019/07/04 职场文书