美文网首页
Javascript——基本数据类型与引用数据类型

Javascript——基本数据类型与引用数据类型

作者: 尛臉仺白 | 来源:发表于2017-10-20 01:23 被阅读0次

在Javascript中,基本数据类型的值是固定大小并且不可变,所以保存在栈内存(stack)中, 引用数据类型恰恰相反,值的大小不固定并且可变,所以保存在堆内存(heap)中。
JavaScript不允许直接访问堆内存,而是把对象存储在堆中的地址放在栈内存中的某个变量里,通过变量来访问到该对象。

无标题.png
  • 何为不可变与可变
//基本数据类型不可变
var str = 'hello world';
console.log(str[4])  // 'o'
str[4] = 'z';
console.log(str)   //'hello world'  
// 引用数据类型可变
var obj = {};
obj.name = 'hello world';
console.log(obj)  //  {name: 'hello world'} 
  • 复制变量值
// 基本类型
var str1 = 'hello world';
var str2 = str1;  // 把str1变量的值的副本复制给str2
str2 = 'hey gay';
console.log(str1, str2)  // 'hello world',  'hey gay'
 
// 引用类型
var obj1 = {}   // obj1保存了一个指向堆内存中一个对象的地址
obj1.name = 'zhangsan';
var obj2 = obj1;  //把地址复制给obj2
obj2.name = 'lisi';  // 因为obj1, obj2都是指向同一个对象,无论修改哪一个另外一个都会随之改变
console.log(obj1.name);  // 'lisi'
console.log(obj2.name)  //  'lisi'

上面例子用图来表示:

无标题2.png 无标题1.png
从图中可以看出,js中无论是基本类型还是引用类型,其变量复制都是值的复制。不同的是基本类型复制的是值本身,而引用类型复制的是地址
  • 传递参数
    在Javascript中,所有函数的参数都是按值传递的,下面是高程三中的一个例子
var obj = new Object();
obj.name = '小明';
function test(o) {   //这里类似变量复制,把obj中保存的地址复制给o
  o.name = '小张';   // obj,o指向的是同一个对象,修改o, obj也会改变
  o = new Object(); // o被重新赋值,值为另一个对象的地址
  o.name = '小红';  // 此时obj, o分别指向不同的对象,修改o不会造成obj的改变
}
test(obj);
console.log(obj.name)  // '小张'

上面代码可以用下图来简单演示

无标题3.png

对象是引用传递, 基础类型是值传递,这句话我想大部分人都在某个地方看到过吧,但是在高程三中又明确写了, 在ECMAScript中,只有值传递,没有引用传递。

timg.jpg

搞事情?想起我学到这的时候真是头皮发麻,瞬间爆炸。。。后来各种百度、Google后才知道这个问题无论是在国外还是在国内都一直是有争议的。好吧,其实纠结哪种说法正确又有何意义呢,了解它的实现机制才是我们所要学习的,毕竟实质大于形式。

下面是我查阅过程中觉得很好的资料,有兴趣的可以自行查阅:
sf社区
知乎
stackoverflow

相关文章

  • JavaScript 数据类型与类型判断详解

    一、JavaScript 数据类型 JavaScript 数据类型有两种,分别是基本数据类型和引用数据类型。 基本...

  • JS类型判断typeof、instanceof、construc

    一、JavaScript 数据类型 JavaScript 数据类型有两种,分别是基本数据类型和引用数据类型。 基本...

  • JavaScript_数据类型

    JavaScript数据类型包括基本数据类型和引用数据类型基本数据类型:null,undefined,string...

  • JavaScript赋值时的传值与传址

    JavaScript中有两种不同数据类型的值,分别是基本数据类型与引用数据类型 基本数据类型包含5类,分别是:Nu...

  • 引用类型对象拷贝

    1.引用类型有哪些?非引用类型有哪些javascript的数据类型分为基本数据类型和引用类型,基本数据类型包括数值...

  • JavaScript原型与原型链

    一、数据类型JavaScript的数据类型可以分为基本数据类型和引用数据类型。 基本数据类型(6种)StringN...

  • 关于JS对象的深浅拷贝

    JavaScript中的数据类型主要分为基本数据类型和引用数据类型。常见基本数据类型主要有:undefined, ...

  • JS的数据类型及其检测

    JavaScript 有几种类型的值? Javascript 有两种数据类型,分别是基本数据类型和引用数据类型。其...

  • JS数据类型

    数据类型分类和区别 分类 javascript数据类型分为:值类型(基本数据类型)、引用数据类型; 区别 值类型 ...

  • javascript修炼之路(三)------数据类型与内存

    一、数据类型分类 javascript中的数据类型分为基本数据类型和引用数据类型。 基本数据类型有五种类型:Num...

网友评论

      本文标题:Javascript——基本数据类型与引用数据类型

      本文链接:https://www.haomeiwen.com/subject/lgryuxtx.html