JS中原始值和引用值的储存方式示例详解


Posted in Javascript onMarch 23, 2018

在ECMAscript中,变量可以存放两种类型的值,即原始值和引用值

  • 原始值指的是代表原始数据类型的值,也叫基本数据类型,包括:Number、Stirng、Boolean、Null、Underfined
  • 引用值指的是复合数据类型的值,包括:Object、Function、Array、Date、RegExp

根据数据类型不同,有的变量储存在栈中,有的储存在堆中。具体区别如下:

原始变量及他们的值储存在栈中,当把一个原始变量传递给另一个原始变量时,是把一个栈房间的东西复制到另一个栈房间,且这两个原始变量互不影响。

引用值是把  引用变量的名称储存在栈中,但是把其实际对象储存在堆中,且存在一个指针由变量名指向储存在堆中的实际对象,当把引用对象传递给另一个变量时,复制的其实是指向实际对象的指针, 此时 两者指向的 是同一个数据,若通过方法改变其中一个变量的值,则访问另一个变量时,其值也会随之加以改变;但若不是通过方法 而是通过 重新赋值  此时 相当于 重新开了一个房间  该值的原指针改变  ,则另外一个 值 不会随他的改变而改变。

看示例:

var a="hello";
var b=a;
a="world";
alert(a);//world
alert(b);//hello
var arr=[1,3];
arr1=arr;
arr.push(5);
alert(arr)//1,3,5
alert(arr1);//1,3,5
arr=[7,8];
alert(arr);//7,8
alert(arr1);//1,3,5

用图来表示 结果如下:

原始变量的值互不影响,引用变量arr和arr1指向的为同一对象,所以当对arr通过方法改变其值时(堆房间里的数据发生变化),访问arr1的数据时就会访问到改变后的对象

JS中原始值和引用值的储存方式示例详解

通过非方法来改变引用变量的值时,会为该引用变量重新创建一个堆房间,此时指针也会发生变化:

JS中原始值和引用值的储存方式示例详解

总结:

Number、Stirng、Boolean、Null、Underfined这些基本数据类型,他们的值直接保存在栈中;

Object、Function、Array、Date、RegExp这些引用类型,他们的引用变量储存在栈中,通过指针指向储存在堆中的实际对象

以上所述是小编给大家介绍的JS中原始值和引用值的储存方式示例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS+CSS实现仿触屏手机拨号盘界面及功能模拟完整实例
May 16 Javascript
理解jquery事件冒泡
Jan 03 Javascript
Ionic如何创建APP项目
Jun 03 Javascript
AngularJS基础 ng-click 指令示例代码
Aug 01 Javascript
详解XMLHttpRequest(一)同步请求和异步请求
Sep 14 Javascript
JavaScript 监控微信浏览器且自带返回按钮时间
Nov 27 Javascript
Vue.js 60分钟快速入门教程
Mar 28 Javascript
node.js中实现kindEditor图片上传功能的方法教程
Apr 26 Javascript
jQuery:unbind方法的使用详解
Aug 14 jQuery
jquery无缝图片轮播组件封装
Nov 25 jQuery
Element Alert警告的具体使用方法
Jul 27 Javascript
vue 使用饿了么UI仿写teambition的筛选功能
Mar 01 Vue.js
剖析Angular Component的源码示例
Mar 23 #Javascript
vue利用axios来完成数据的交互
Mar 23 #Javascript
JS动画定时器知识总结
Mar 23 #Javascript
p5.js 毕达哥拉斯树的实现代码
Mar 23 #Javascript
轻量级JS Cookie插件js-cookie的使用方法
Mar 22 #Javascript
浅谈Webpack 持久化缓存实践
Mar 22 #Javascript
深入浅析Vue.js中 computed和methods不同机制
Mar 22 #Javascript
You might like
中国收音机工业发展史
2021/03/02 无线电
php获取地址栏信息的代码
2008/10/08 PHP
php 接口类与抽象类的实际作用
2009/11/26 PHP
PHP中的string类型使用说明
2010/07/27 PHP
使用PHP实现阻止用户上传成人照片或者裸照
2014/12/25 PHP
php实现短信发送代码
2015/07/05 PHP
PHP实现动态执行代码的方法
2016/03/25 PHP
Javascript 实用小技巧
2010/04/07 Javascript
js 关键词高亮(根据ID/tag高亮关键字)案例介绍
2013/01/21 Javascript
jquery删除ID为sNews的tr元素的内容
2014/04/10 Javascript
IE6中链接A的href为javascript协议时不在当前页面跳转
2014/06/05 Javascript
jQuery实现列表自动滚动循环滚动展示新闻
2014/08/22 Javascript
提高jQuery性能优化的技巧
2015/08/03 Javascript
angularJS Provider、factory、service详解及实例代码
2016/09/21 Javascript
使用smartupload组件实现jsp+jdbc上传下载文件实例解析
2017/01/05 Javascript
Vue基于NUXT的SSR详解
2017/10/24 Javascript
VUE2.0+Element-UI+Echarts封装的组件实例
2018/03/02 Javascript
基于vue中css预加载使用sass的配置方式详解
2018/03/13 Javascript
Angular 组件之间的交互的示例代码
2018/03/24 Javascript
Python中 Lambda表达式全面解析
2016/11/28 Python
tensorflow: 查看 tensor详细数值方法
2018/06/13 Python
python实现顺时针打印矩阵
2019/03/02 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
解决pycharm remote deployment 配置的问题
2019/06/27 Python
tensorflow对图像进行拼接的例子
2020/02/05 Python
文员个人的求职信范文
2013/09/26 职场文书
上班离岗检讨书
2014/01/27 职场文书
人事主管岗位职责
2014/01/30 职场文书
求职信需要的五点内容
2014/02/01 职场文书
领导干部作风建设总结
2014/10/23 职场文书
化验员岗位职责
2015/02/14 职场文书
大学生自荐信范文
2015/03/05 职场文书
生日赠语
2015/06/23 职场文书
婚宴致辞
2015/07/28 职场文书
Python 居然可以在 Excel 中画画你知道吗
2022/02/15 Python
解决Mysql中的innoDB幻读问题
2022/04/29 MySQL