Javascript专栏(二)_数据类型

本文介绍了JavaScript的数据类型,包括基本数据类型与引用数据类型的差异,如内存分配、访问机制、复制、参数传递和可变性。同时,讨论了Boolean对象、如何判断变量类型的方法,如typeof、instanceof和Object.prototype.toString.call()。还阐述了null和undefined的区别,并讨论了深浅拷贝的概念及其常见实现方式。
摘要由CSDN通过智能技术生成

我们在研究如何得到某个变量的类型之前,先回顾一下JavaScript都有哪些类型呢?

1. 类型介绍

  • 基本数据类型
    1. 数值类型
      • Number
      • BigInt类型
    2. String
    3. Bollean
    4. Null
    5. Undefined
    6. Symbol 符号。ES2015新增
  • 引用数据类型
    1. Object
      • Function
      • Array
      • Date
      • RegExp 正则表达式

1.1 基本数据类型和引用数据类型的区别

1.1.1 声明变量时分配的内存不同

  1. 原始值:存储在栈(stack)中的简单数据段,也就是说,它们的值直接存储在变量访问的位置。
  2. 引用值:存储在堆(heap)中的对象,也就是说,存储在变量处的值是一个指针(point),指向存储对象的内存地址。

1.1.2 不同的内存分配机制也带来了不同的访问机制

  1. 在javascript中是不允许直接访问保存在堆内存中的对象的,所以在访问一个对象时,
    首先得到的是这个对象在堆内存中的地址,然后再按照这个地址去获得这个对象中的值,这就是传说中的按引用访问。
  2. 而原始类型的值则是可以直接访问到的

1.1.3 复制变量时的不同

  1. 原始值:在将一个保存着原始值的变量复制给另一个变量时,会将原始值的副本赋值给新变量,此后这两个变量是完全独立的,他们只是拥有相同的value而已。
var a = 20;
var b = a;
b = 30;
console.log(a); // 仍是20
// 因为b获取的是a值的一份拷贝,b更改不会影响a


2. 引用值:在将一个保存着对象内存地址的变量复制给另一个变量时,会把这个内存地址赋值给新变量,也就是说这两个变量都指向了堆内存中的同一个对象,他们中任何一个作出的改变都会反映在另一个身上。(这里要理解的一点就是,复制对象时并不会在堆内存中新生成一个一模一样的对象,只是多了一个保存指向这个对象指针的变量罢了)。多了一个指针

var obj1 = new Object()
var obj2 = obj1; // obj1赋值给obj2,实际上是把obj1在栈内存的引用地址复制了一份给obj2 这样的话他们就会指向同一个堆内存对象
obj2.name = 'jxx'
console.log(obj1.name); // jxx

1.1.4 参数传递的不同

当两者作为函数的参数进行传递时:

  1. 基本数据类型传入的是数据的副本,原数据的更改不会影响传入后的数据
  2. 引用数据类型传入的是数据的引用地址,原数据的更改会影响传入后的数据

1.1.5 值的可变性不同

1.2 Bollean对象与Bollean类型

Bollean类型不再赘述,在这里我们讨论一下Bollean对象

var x = new Boolean(false) // true
var x = Boolean(false)  // false

不要用创建 Boolean 对象的方式将一个非布尔值转化成布尔值,直接将 Boolean 当做转换函数来使用即可。因为对于任何对象,即使是值为 false 的 Boolean 对象,当将其传给 Boolean 函数时,生成的 Boolean 对象的值都是 true。

var x = new Boolean(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值