JavaScript数据类型及其存储方式详细梳理

 更新时间:2026年03月11日 09:26:22   作者:Sun_light  
JavaScript是一种弱类型语言,它提供了许多不同的数据类型用于存储和操作数据,下面这篇文章主要介绍了JavaScript数据类型及其存储方式的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

JavaScript 作为一门动态、弱类型的编程语言,数据存储方式与传统静态语言有很大不同。理解 JS 的数据类型、内存分配机制以及数据存储的底层原理非常重要。本文将围绕“数据类型”、“语言类型特性”以及“内存空间”三个核心点,带你系统梳理 JavaScript 的数据存储原理。

JavaScript 的数据类型

1. 原始类型(基本类型)

原始类型是最基本的数据单元,存储在栈内存中,具有不可变性。包括:

  • String:字符串,如 "hello"

  • Number:数字,包括整数和浮点数,如 423.14

  • Boolean:布尔值,truefalse

  • null:表示“无”或“空值”

  • undefined:变量声明但未赋值时的默认值

  • Symbol:ES6 新增,表示独一无二的值,常用于对象属性的唯一标识

  • BigInt:大整数类型,用于处理超出最大安全整数范围的数值

特点:

  • 占用空间小,存储在栈内存

2. 引用类型(复杂类型)

引用类型用于存储复杂的数据结构,存储在堆内存中。包括:

  • Object:对象,如 {name: "Hua"}

  • Array:数组,如 [1, 2, 3]

  • Function:函数本质上也是对象

  • Date:日期对象

特点:

  • 占用空间大,存储在堆内存
  • 变量存储的是指向堆内存的引用(地址)

JavaScript 的类型特性

1. 静态语言与动态语言

  • 静态语言:在使用前就需要确定变量的类型,编译时类型已知。例如 Java、C++

  • 动态语言:在使用时不需要确定变量的类型,运行时根据赋值的变量类型来确定。例如 JavaScript、Python

JS 是动态类型语言,变量的类型在运行时根据赋值自动确定。例如:

let a = 10;      // Number
a = "hello";     // String
a = [1, 2, 3];   // Array

2. 强类型与弱类型

  • 强类型语言:不支持隐式类型转换,类型不兼容时会报错

  • 弱类型语言:支持隐式类型转换,类型可以自动转换 JS 支持隐式类型转换。例如:

console.log(1 + "2"); // "12"
console.log("5" - 2); // 3

这种灵活性带来了便利,但也容易引发类型相关的 bug。

内存空间与数据存储

1. V8 引擎的内存空间划分

V8 是 Chrome 和 Node.js 使用的 JS 引擎。它在执行 JS 代码时,会划分出三大内存空间:

  • 代码空间:存放代码文本本身
  • 栈空间:用于存储原始类型变量、函数调用上下文等
  • 堆空间:用于存储引用类型数据(对象、数组、函数等

栈空间(Stack)

  • 结构简单,先进后出
  • 存储原始类型和执行上下文
  • 访问速度快,空间有限

堆空间(Heap)

  • 结构复杂,无序
  • 存储引用类型数据
  • 空间大,访问速度相对慢

2. 原始类型与引用类型的存储方式

  • 原始类型:变量直接存储值本身,分配在栈空间
  • 引用类型:变量存储的是指向堆内存的地址(引用),实际数据存储在堆空间

示例

let a = 10;           // 原始类型,a 存储 10
let b = {num: 1};       // 引用类型,b 存储堆中对象的地址
let c = b;            // c 也指向同一个对象
c.num = 2;
console.log(b.num);     // 2

实战面试题

看完以上内容,相信你已经对数据类型与其存储方式已经很了解了,让我们来做一道经典的面试题

function foo(person) {
    person.age = 20
    person = {
        name: '小钟'
    }
    return person
}
let p1 = {
    name: '小华',
    age: 18
}
let p2 = foo(p1)

console.log(p1);
console.log(p2);

运行结果

输出为:

{ name: '小华', age: 20 }
{ name: '小钟' }

过程详解

  • let p1 = { name: '小华', age: 18 }
    这里,p1 是一个引用类型变量,存储的是对象在堆内存中的地址。

  • let p2 = foo(p1)
    调用 foo 时,person 形参获得了 p1 的地址副本。此时 personp1 都指向同一个对象。

  • person.age = 20
    通过 person 修改对象的 age 属性,由于 personp1 指向同一个对象,所以 p1.age 也变成了 20。

  • person = { name: '小钟' }
    这一步,person 被赋值为一个新对象的地址。此时 person 指向新对象,而 p1 依然指向原来的对象。两者不再关联。

  • return person
    返回的是新对象 { name: '小钟' },赋值给 p2

总结

JavaScript 的数据存储机制是理解 JS 语言的基础。原始类型和引用类型的本质区别在于存储位置和可变性。原始类型存储在栈空间,体积小、不可变;引用类型存储在堆空间,体积大、可变。JS 作为动态、弱类型语言,变量类型可以随时变化,类型之间可以自动转换。

到此这篇关于JavaScript数据类型及其存储方式的文章就介绍到这了,更多相关JS数据类型及存储方式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JS面向对象编程实现的Tab选项卡案例详解

    JS面向对象编程实现的Tab选项卡案例详解

    这篇文章主要介绍了JS面向对象编程实现的Tab选项卡,结合具体案例形式详细分析了JS基于面向对象程序设计实现Tab选项卡的相关操作技巧,需要的朋友可以参考下
    2020-03-03
  • 如何用JS模拟实现数组的map方法

    如何用JS模拟实现数组的map方法

    这篇文章主要介绍了如何用JS模拟实现数组的map方法,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • newxtree.js代码

    newxtree.js代码

    newxtree.js代码...
    2007-03-03
  • JavaScript对象字面量和构造函数原理与用法详解

    JavaScript对象字面量和构造函数原理与用法详解

    这篇文章主要介绍了JavaScript对象字面量和构造函数,结合实例形式分析了JavaScript对象字面量和构造函数相关概念、原理、用法及操作注意事项,需要的朋友可以参考下
    2020-04-04
  • 微信jssdk用法汇总

    微信jssdk用法汇总

    这篇文章主要针对微信jssdk用法进行汇总,通过ready接口处理成功验证、通过error接口处理失败验证等内容介绍,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • JavaScript隐式类型转换

    JavaScript隐式类型转换

    JavaScript的数据类型是非常弱的(不然不会叫它做弱类型语言了)!在使用算术运算符时,运算符两边的数据类型可以是任意的,比如,一个字符串可以和数字相加
    2016-03-03
  • DIV菜单层实现代码

    DIV菜单层实现代码

    昨天我问一美工jQuery怎么样了,他说简单的还可以,复杂的就不行了,我又问是哪种程度的复杂?
    2010-11-11
  • ImageZoom 图片放大镜效果(多功能扩展篇)

    ImageZoom 图片放大镜效果(多功能扩展篇)

    上一篇ImageZoom已经对图片放大效果做了详细的分析,这次在ImageZoom的基础上进行扩展,实现更多的效果。
    2010-04-04
  • JS如何判断浏览器类型和详细区分IE各版本浏览器

    JS如何判断浏览器类型和详细区分IE各版本浏览器

    本篇文章主要介绍了JS判断浏览器类型和详细区分IE各版本浏览器的代码,非常具有实用价值,有兴趣的可以了解一下。
    2017-03-03
  • javascript中JSON对象与JSON字符串相互转换实例

    javascript中JSON对象与JSON字符串相互转换实例

    这篇文章主要介绍了javascript中JSON对象与JSON字符串相互转换,实例分析了json对象与字符串常用的几种转换技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07

最新评论