JS—基本数据类型和引用数据类型:1分钟掌握两者的区别

news2025/3/19 9:09:51

个人博客:haichenyi.com。感谢关注

一. 目录

  • 一–目录
  • 二–分类
  • 三–核心区别
  • 四–实际场景中的问题
  • 五–总结对比

二. 分类

前面说过这么判断数据类型,今天来说说基本数据类型和引用数据类型的区别。

基本数据类型引用数据类型
StringObject
NumberFunction
nullDate
undefinedArray
Symbol(符号,ES6+)RegExp
Boolean其他内置对象
BigInt(大整数,ES11+)

三. 核心区别

内存分配方式

  • 基本数据类型:直接存储在栈内存(Stack)中,变量直接保存数据值。
let a = 10; // 栈中存储值 10
let b = a;  // 栈中拷贝一份新的值 10 给 b
  • 引用数据类型:数据存储在堆内存(Heap)中,变量保存的是堆内存地址(指针)​。
let obj1 = { name: 'Alice' }; // 堆中存储对象,obj1 保存地址
let obj2 = obj1;              // obj2 拷贝的是地址,指向同一个对象

赋值行为的差异

  • 基本数据类型:赋值是 ​值的拷贝,新旧变量完全独立。
let a = 10;
let b = a;
b = 20;
console.log(a); // 10(a 不受影响)
  • 引用数据类型:赋值是 ​地址的拷贝,新旧变量共享同一数据。
let obj1 = { count: 0 };
let obj2 = obj1;
obj2.count = 100;
console.log(obj1.count); // 100(共享同一对象)

比较操作的差异

  • 基本数据类型:直接比较 ​值 是否相等。
let a = 10;
let b = 10;
console.log(a === b); // true(值相同)
  • 引用数据类型:比较的是 ​内存地址 是否相同,而非内容。
let arr1 = [1, 2];
let arr2 = [1, 2];
console.log(arr1 === arr2); // false(地址不同)

函数参数传递的差异

  • 基本数据类型:传递的是 ​值的副本,函数内部修改不影响外部变量。
function changeValue(num) {
  num = 100;
}
let a = 10;
changeValue(a);
console.log(a); // 10(不变)
  • 引用数据类型:传递的是 ​地址的副本,函数内部修改会直接影响外部对象。
function updateObj(obj) {
  obj.key = 'new value';
}
let myObj = { key: 'old value' };
updateObj(myObj);
console.log(myObj.key); // 'new value'(被修改)

可变性(Mutability)​

  • 基本数据类型:不可变(Immutable)​,任何操作都会创建新值。
let str = 'hello';
str.toUpperCase(); // 返回新字符串 'HELLO'
console.log(str);  // 'hello'(原值未变)
  • 引用数据类型:可变(Mutable)​,可以直接修改内容。
let arr = [1, 2];
arr.push(3);
console.log(arr); // [1, 2, 3](原数组改变)//有点牵强,毕竟数组操作方法也存在不改变原数组的方法

垃圾回收机制

  • 基本数据类型:变量销毁时,栈内存直接释放。
  • 引用数据类型:需要依赖垃圾回收器(GC)检查堆内存中的对象是否无引用,再决定回收。(具体可以看一下前面讲的垃圾回收机制)

四. 实际场景中的问题

  1. ​深拷贝 vs 浅拷贝
    引用类型的直接赋值(浅拷贝)会导致共享数据问题,需深拷贝解决:
// 浅拷贝
let obj = { a: 1 };
let shallowCopy = obj;

// 深拷贝(常用方法),后面再讲讲常用的深拷贝的方式吧
let deepCopy = JSON.parse(JSON.stringify(obj));
  1. 性能优化
    基本类型操作更快(内存占用小),引用类型操作可能涉及堆内存访问。

五. 总结对比

特性基本数据类型引用数据类型
存储位置栈内存堆内存
赋值行为值拷贝地址拷贝
比较方式值比较地址比较
参数传递值传递地址传递

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2317696.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

解决MySQL字符集冲突引发的“Illegal mix of collations”错误

引言 在开发过程中,我们常常会遇到数据库层面的字符集兼容性问题。本文将通过一个典型的案例,分析因字符集不匹配导致的 Illegal mix of collations 错误,并提供完整的解决方案,帮助开发者彻底规避此类问题。 问题现象 假设我们…

Vue中的publicPath释义

publicPath 部署应用包时的基本URL。用法和 webpack 本身的 output.publicPath 一致,但是 Vue CLI 在一些其他地方也需要用到这个值,所以请始终使用 publicPath 而不要直接修改 webpack 的 output.publicPath。 默认情况下,Vue CLI 会假设你…

新造车不再比拼排名,恰是曲终人散时,剩者为王

据称新能源汽车周销量不再发布,这可能也预示着新造车终于到了给出答案的时候了,新造车企业前三强已基本确立,其余那些落后的车企已很难有突围的机会,而特斯拉无疑是其中的最大赢家。 3月份第一周的数据显示,销量最高的…

博客迁移----宝塔面板一键迁移遇到问题

前景 阿里云轻量级服务器到期了,又免费领了个ESC, 安转了宝塔面板。现在需要迁移数据,使用宝塔面板一键迁移功能,完成了数据的迁移,改了域名的解析,现在进入博客是显示502 bad grateway 宝塔搬家参考链接…

大数据处理最容易的开源平台

大数据处理最容易的开源平台可以从多个角度进行分析,包括易用性、灵活性、成本效益以及社区支持等方面。 Apache Spark Apache Spark 是一个广泛使用的开源大数据处理框架,以其快速、通用和易于使用的特点而著称。它支持多种编程语言(如 Scal…

Dify 使用 - 创建 翻译 工作流

文章目录 1、选择 模板2、设置 和 基本使用3、运行应用 1、选择 模板 2、设置 和 基本使用 翻译模板 自带了系统提示词,你也可以修改 3、运行应用 右上角 点击 发布 – 更新,运行应用,就可以在新的对话界面中使用此功能 2025-03-18&#x…

TreelabPLMSCM数字化供应链解决方案0608(61页PPT)(文末有下载方式)

详细资料请看本解读文章的最后内容。 资料解读:TreelabPLMSCM 数字化供应链解决方案 0608 在当今快速变化的市场环境中,企业面临着诸多挑战,Treelab 数智化 PLM_SCM 行业解决方案应运而生。该方案聚焦市场趋势与行业现状,致力于解…

LogicFlow介绍

LogicFlow介绍 LogicFlow是一款流程图编辑框架,提供了一系列流程图交互、编辑所必需的功能和灵活的节点自定义、插件等拓展机制。LogicFlow支持前端自定义开发各种逻辑编排场景,如流程图、ER图、BPMN流程等。在工作审批流配置、机器人逻辑编排、无代码平…

[蓝桥杯 2023 省 B] 飞机降落

[蓝桥杯 2023 省 B] 飞机降落 题目描述 N N N 架飞机准备降落到某个只有一条跑道的机场。其中第 i i i 架飞机在 T i T_{i} Ti​ 时刻到达机场上空,到达时它的剩余油料还可以继续盘旋 D i D_{i} Di​ 个单位时间,即它最早可以于 T i T_{i} Ti​ 时刻…

应用分层简介

一、什么是应用分层 应用分层是一种软件开发设计思想,它将应用程序分为多个层次,每个层次各司其职,多个层次之间协同提供完整的功能,根据项目的复杂程度,将项目分为三层或者更多层。 常见的MCV设计模式,就…

基于香橙派 KunpengPro学习CANN(3)——pytorch 模型迁移

通用模型迁移适配可以分为四个阶段:迁移分析、迁移适配、精度调试与性能调优。 迁移分析 迁移支持度分析: 准备NPU环境,获取模型的源码、权重和数据集等文件;使用迁移分析工具采集目标网络中的模型/算子清单,识别第三方…

电子硬件入门(三)——偏置电路

文章目录 一、先理解问题:为什么需要偏置电压?二.偏置电路生成的四大核心零件​三、工作流程图解​四、实物电路对照​五、常见问题答疑 一、先理解问题:为什么需要偏置电压? 想象一下,电机的电流像一条波浪线&#x…

使用C++写一个递推计算均方差和标准差的用例

文章目录 代码输出关键实现说明1. 类设计2. 算法核心3. 数值稳定性 扩展应用场景1. 实时传感器数据处理2. 大规模数据集分块处理 总结 以下是用 C 实现递推计算均值、方差和标准差的完整示例代码,基于 Welford 算法,适用于实时数据流或大数据场景&#x…

Vue:单文件组件

Vue:单文件组件 1、 什么是单文件组件? 在传统的Vue开发里,我们接触的是非单文件组件,它们通常被定义在同一个HTML文件中,随着项目规模的扩大,代码会变得杂乱无章,维护起来极为困难。而单文件…

JavaScript变量声明与DOM操作指南

变量声明 1.变量声明有三个 var let 和 const 我们应该用那个呢? 首先var 先排除,老派写法,问题很多,可以淘汰掉… 2.let or const ? 建议: const 优先,尽量使用const,原因是:…

[K!nd4SUS 2025] Crypto

最后一个把周末的补完。这个今天问了小鸡块神终于把一个补上,完成5/6,最后一个网站也上不去不弄了。 Matrices Matrices Matrices 这个是不是叫LWE呀,名词忘了,但意思还是知道。 b a*s e 这里的e是高斯分成,用1000…

工作记录 2017-02-04

工作记录 2017-02-04 序号 工作 相关人员 1 修改邮件上的问题。 更新RD服务器。 郝 更新的问题 1、DataExport的设置中去掉了ListPayors,见DataExport\bin\dataexport.xml 2、“IPA/Group Name” 改为 “Insurance Name”。 3、修改了Payment Posted的E…

Etcd 服务搭建

💢欢迎来到张胤尘的开源技术站 💥开源如江河,汇聚众志成。代码似星辰,照亮行征程。开源精神长,传承永不忘。携手共前行,未来更辉煌💥 文章目录 Etcd 服务搭建预编译的二进制文件安装下载 etcd 的…

【C++】stack和queue的使用及模拟实现(含deque的简单介绍)

文章目录 前言一、deque的简单介绍1.引入deque的初衷2.deque的结构3.为什么选择deque作为stack和queue的底层默认容器 二、stack1.stack的介绍2.stack的使用3.stack的模拟实现 三、queue1.queue的介绍2.queue的使用3.queue的模拟实现 前言 一、deque的简单介绍(引入…

MySQL原理:逻辑架构

目的:了解 SQL执行流程 以及 MySQL 内部架构,每个零件具体负责做什么 理解整体架构分别有什么模块每个模块具体做什么 目录 1 服务器处理客户端请求 1.1 MySQL 服务器端逻辑架构说明 2 Connectors 3 第一层:连接层 3.1 数据库连接池(Conn…