惊呼!JavaScript基本数据类型和引用数据类型详解

Posted 小歌谣(公众号同名)

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了惊呼!JavaScript基本数据类型和引用数据类型详解相关的知识,希望对你有一定的参考价值。

前言

我是歌谣 知其然知其所以然 人人都有一个大厂梦 希望通过自己的一个总结分享可以给予大家带来帮助和提升。

本期知识点

javascript中基本数据类型和引用数据类型

目标

  1. 理解基本数据类型和引用数据类型的定义
  2. 理解堆和栈
  3. 数据类型分为哪些

定义

ECMAScript包括两个不同类型的值:基本数据类型和引用数据类型。
 基本数据类型指的是简单的数据段,引用数据类型指的是有多个值构成的对象。
 当我们把变量赋值给一个变量时,解析器首先要确认的就是这个值是基本类型值还是引用类型值。

常见的数据类型

基本数据类型

  • Sting
  • Number
  • Boolean
  • null
  • undefined
  • Symbol

引用数据类型

  • Object
  • Date
  • function
  • RegExp
  • Array …

栈内存(stack)

栈内存:是一种特殊的线性表,它具有后进先出的特性,存放基本类型。

在这里插入图片描述

堆内存(heap)

在这里插入图片描述

区别

1复制变量时的不同
对于基本类型来说,一般会在变量对象上创建一个新值,然后把这个值复制到为新变量分配的类型上面
对于引用类型来说,也会将存储在变量对象的值复制一份到新变量的内存空间中,但是这个值的副本其实是一个指针,这个指针指向我们被赋值的对象,即不管怎么样,引用类型的赋值其实都是引用的同一个对象

2参数传递的不同
首先我们应该明确一点:ECMAScript中所有函数的参数都是按值来传递的。
原始值:只是把变量里的值传递给参数,之后参数和这个变量互不影响。
引用值:对象变量它里面的值是这个对象在堆内存中的内存地址,因此它传递的值也就是这个内存地址,这也就是为什么函数内部对这个参数的修改会体现在外部的原因了,因为它们都指向同一个对象。

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

检测方法

可以通过typeof检测基本类型和复杂类型,不过检测出来的复杂类型都是Object,如果想要检测复杂类型可以通过 instanceof
语法:object instanceof constructor

var a1=0;                 // typedof a1 -> number
var a2 = 'this is str';  //typedof a2 -> string
var a3 =null;           //typedof a3 -> null
var c= [1,2,3];        // c instanceof Array  ->true
var b={m:20};         // b instanceof Object ->true

总结

面试中经常会问我们基本数据类型有哪些
我是歌谣 放弃很容易 坚持一定很酷 纯属个人总结 若有不合理之处 可选择性关闭网页 欢迎讨论
下一期预计开始讲解原型和原型链部分 敬请期待

以上是关于惊呼!JavaScript基本数据类型和引用数据类型详解的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript 基本数据类型和引用类型的区别详解

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

JavaScript 引用类型

JavaScript基本包装类介绍

JavaScript中的包装类

JavaScript高级程序设计 引用类型 (上)