JS数据类型有哪些?存储上有什么区别?

简介: JS数据类型有哪些?存储上有什么区别?

首先数据类型一共有8种,这八种数据类型又分为基本数据类型和引用数据类型

基本数据类型:Undefined、Null、Boolean、Number、String、Symbol、BigInt

引用数据类型:Object [数组对象:Array 日期对象:Date 数学对象:Math 函数对象:Function 正则对象:RegExp]

基本数据类型:

【直接存储在栈内存中的,可以直接访问,赋值时是将原始值复制一份到新的变量中】

let num1 = 123; // 值为数字123,存储在栈内存中
let str1 = "hello world"; // 值为字符串"hello world",存储在栈内存中
let bool1 = true; // 值为布尔值true,存储在栈内存中
let null1 = null; // 值为null,表示空对象引用,存储在栈内存中
let undefined1 = undefined; // 值为undefined,表示未定义,存储在栈内存中
let sym1 = Symbol("foo"); // 值为符号,存储在栈内存中

引用数据类型:

【储在堆内存中的,变量中保存的实际上是一个指向堆内存中实际对象的指针。因此,它们的赋值是传递的是指针地址,而不是复制一份值】

let obj1 = { name: "Tom", age: 20 }; // 值为一个对象,存储在堆内存中
let arr1 = [1, 2, 3]; // 值为一个数组,存储在堆内存中
let fn1 = function() {}; // 值为一个函数,存储在堆内存中

原始数据类型直接存储在栈(stack)中的简单数据段,占据空间小、大小固定,属于被频繁使用数据,所以放入栈中存储;

引用数据类型存储在堆(heap)中的对象,占据空间大、大小不固定。如果存储在栈中,将会影响程序运行的性能;引用数据类型在栈中存储了指针,该指针指向堆中该实体的起始地址。当解释器寻找引用值时,会首先检索其在栈中的地址,取得地址后从堆中获得实体。

注:

引用类型的值是分配在堆内存中的,因此相应的访问时间、访问速度也会受到环境和内存使用情况的影响。

同时,由于引用类型的值是通过指针来访问的,所以相应的访问速度也会比较慢,而且需要更多的内存空间。

可以参考的博客:【说一说JS数据类型有哪些,区别是什么? - 知乎


相关文章
|
4天前
|
存储 JavaScript 前端开发
JavaScript中的数据类型以及存储上的差别
通过本文的介绍,希望您能够深入理解JavaScript中的数据类型及其存储差别,并在实际编程中灵活运用这些知识,以提高代码的性能和稳定性。
20 3
|
28天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
26 1
|
28天前
|
存储 JavaScript 前端开发
js中的数据类型
JavaScript 中的数据类型包括五种基本类型(String、Number、Undefined、Boolean、Null)和三种引用类型(Object、Array、Function,以及ES6新增的Symbol)。基本类型直接存储值,引用类型存储的是指向实际数据的内存地址。了解它们的区别对于掌握 JavaScript 的变量赋值和函数传参至关重要。
21 1
|
1月前
|
设计模式 JavaScript 前端开发
js中new和object.creat区别
【10月更文挑战第29天】`new` 关键字和 `Object.create()` 方法在创建对象的方式、原型链继承、属性初始化以及适用场景等方面都存在差异。在实际开发中,需要根据具体的需求和设计模式来选择合适的方法来创建对象。
|
2月前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
108 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
JavaScript 前端开发 开发者
【干货拿走】JavaScript中最全的数据类型判断方法!!!!
【干货拿走】JavaScript中最全的数据类型判断方法!!!!
27 1
|
2月前
|
存储 JavaScript 前端开发
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
44 0
|
存储 JavaScript 前端开发
JavaScript实现存储HTML字符串
原文:JavaScript实现存储HTML字符串 吃完晚饭,在翻各位大牛的博客,偶然看到一篇原创《原创--Javascript你意想不到的功能!!!》眼前一亮,这思路确实霸气测漏,可以不用理会字符串的单引号和双引号的转义,因为人家用的是注释,注释当然什么都可以写。
1131 0
|
存储 JavaScript 前端开发
JavaScript实现存储HTML字符串
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> Function.prototype.heredoc = function(){ // 利用 function 的注释来存储字符串,而且无需转义。
725 0