JavaScript 简单类型与复杂类型-复杂类型的内存分配

深入理解JavaScript中的简单类型(基本数据类型)和复杂类型(引用数据类型)如何在内存中存储对于编写高效、无误的代码至关重要。本文将专注于探讨复杂类型的内存分配机制,即堆(Heap)内存,并通过实例说明这些概念的实际应用。

内存基础:栈与堆

栈(Stack)

栈是一种后进先出(LIFO, Last In First Out)的数据结构,通常用于存储函数调用信息和局部变量。由于其结构特性,栈操作非常快速且直接,访问栈顶元素的时间复杂度为O(1)。简单类型的数据值就存储在栈内存中。

堆(Heap)

堆是一种动态分配的内存区域,适合于存储大小不固定的对象或需要长期存在的数据。与栈不同,堆上的数据没有特定的顺序,因此访问速度较慢,但灵活性更高。复杂类型的值实际存储在堆中,而栈中仅保存指向堆内存的引用地址。

  • 特点
    • 存储复杂类型值。
    • 所有线程共享同一块堆内存。
    • 动态分配,管理相对复杂。

复杂类型的内存分配

JavaScript中的复杂类型包括:

  • Object
  • Array
  • Function
  • 其他自定义对象

复杂类型的值是按引用传递的,这意味着当一个复杂类型的值被赋给另一个变量时,实际上是创建了一个新的引用,指向同一个堆内存地址。

示例1:对象的赋值

let obj1 = { name: "Alice" };
let obj2 = obj1;

console.log(obj1); // 输出: { name: 'Alice' }
console.log(obj2); // 输出: { name: 'Alice' }

obj2.name = "Bob";

console.log(obj1.name); // 输出: Bob
console.log(obj2.name); // 输出: Bob

在这个例子中,obj1obj2都指向了堆中同一个对象,所以修改其中一个对象会影响另一个对象。

示例2:比较复杂类型的值

let arr1 = [1, 2, 3];
let arr2 = [1, 2, 3];

console.log(arr1 === arr2); // 输出: false

let obj1 = { key: "value" };
let obj2 = obj1;

console.log(obj1 === obj2); // 输出: true

这里,尽管arr1arr2包含相同的元素,但由于它们是不同的对象实例,各自的引用地址不同,所以比较结果为false。而obj1obj2指向同一个对象,因此比较结果为true

深拷贝 vs 浅拷贝

由于复杂类型是按引用传递的,直接赋值不会复制对象本身,而是复制了引用。为了创建对象的独立副本,我们需要使用深拷贝技术。

浅拷贝

浅拷贝只复制对象的第一层属性,如果对象中含有嵌套的对象或数组,则复制的是这些嵌套对象的引用,而不是完整的副本。

let original = { a: 1, b: { c: 2 } };
let shallowCopy = Object.assign({}, original);

original.b.c = 3;

console.log(shallowCopy.b.c); // 输出: 3

深拷贝

深拷贝则会递归地复制整个对象树,确保新对象与原对象完全独立。

let original = { a: 1, b: { c: 2 } };
let deepCopy = JSON.parse(JSON.stringify(original));

original.b.c = 3;

console.log(deepCopy.b.c); // 输出: 2

注意:使用JSON.parse(JSON.stringify())进行深拷贝存在局限性,例如它不能处理函数、循环引用等特殊情况。

实际应用场景

场景1:对象的持久化

当你需要保存对象的状态以便后续恢复时,深拷贝是非常有用的。

function saveState(state) {
    return JSON.parse(JSON.stringify(state));
}

let gameState = { level: 1, score: 100, player: { name: "Hero", health: 100 } };
let savedState = saveState(gameState);

gameState.level = 2;
gameState.player.health = 80;

console.log(savedState); // 输出: { level: 1, score: 100, player: { name: 'Hero', health: 100 } }

场景2:函数作为参数传递

复杂类型也可以作为参数传递给函数,在这种情况下,传入的是对象的引用。

function updatePlayer(player) {
    player.health -= 10;
}

let player = { name: "Hero", health: 100 };

updatePlayer(player);

console.log(player.health); // 输出: 90

结语

感谢您的阅读!如果你有任何问题或想分享自己的经验,请在评论区留言交流!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

有道云数据下载导出到本地结合Typora-v1.9.5 解锁版解压版构建本地笔记库

1、下载python 导出脚本 脚本下载:yodaonote-pull 2、安装python 依赖包 3、获取有道云cookies 通过有道云网页版登录获取cookies 方式一:浏览器F12 方式二:chrome 浏览器插件Cookie-copy 查看 4、配置导出路径 配置cookies.json {…

【一起学Rust | Tauri2.0框架】单实例应用程序的深入解析:零漏洞实现与优化实战

文章目录 前言一、 单实例应用的意义二、 实现单实例应用的方法1 Windows下的实现1.1 创建命名Mutex1.2 在Tauri应用中集成Mutex检查 2 macOS下的实现2.1 获取Bundle Identifier2.2 检查是否已经有实例在运行 3 Linux下的实现3.1 获取进程列表3.2 检查是否已经有实例在运行 4 在…

和鲸科技携手四川气象,以 AI 的力量赋能四川气象一体化平台建设

气象领域与农业、能源、交通、环境科学等国计民生关键领域紧密相连,发挥着不可替代的重要作用。人工智能技术的迅猛发展,为气象领域突破困境带来了新的契机。AI 技术能够深度挖掘气象大数据中蕴含的复杂信息,助力人类更精准地把握自然规律&am…

autojs例子之webView的UA切换

/*** 作者: 家* QQ: 203118908* 功能: webViewUA切换*/ "ui"; importClass(java.io.File); importPackage(android.text); importPackage(android.text.style);ui.layout(<vertical id"yidong1" marginTop0 bg"#881e90ff"><text id&q…

HarmonyOS 5.0应用开发——鸿蒙接入高德地图实现POI搜索

【高心星出品】 文章目录 鸿蒙接入高德地图实现POI搜索运行结果&#xff1a;准备地图编写ArkUI布局来加载HTML地图 鸿蒙接入高德地图实现POI搜索 在当今数字化时代&#xff0c;地图应用已成为移动设备中不可或缺的一部分。随着鸿蒙系统的日益普及&#xff0c;如何在鸿蒙应用中…

Python爬虫(四)- Selenium 安装与使用教程

文章目录 前言一、简介及安装1. Selenium 简介2. Selenium 安装 二、Selenium 基本使用1. 导入Selenium2. 启动浏览器3. 打开网页4. 获取页面标题5. 关闭浏览器6. 完整示例代码 三、Selenium WebDriver1. 简介2. 基本操作2.1 启动浏览器2.2 关闭浏览器2.3 打开网页2.4 关闭当前…

java后端开发day20--面向对象进阶(一)--static继承

&#xff08;以下内容全部来自上述课程&#xff09; 1.static–静态–共享 static表示静态&#xff0c;是java中的一个修饰符&#xff0c;可以修饰成员方法&#xff0c;成员变量。 1.静态变量 被static修饰的成员变量&#xff0c;叫做静态变量。 特点&#xff1a; 被该类…

phpstudy安装教程dvwa靶场搭建教程

GitHub - digininja/DVWA: Damn Vulnerable Web Application (DVWA) Dvwa下载地址 Windows版phpstudy下载 - 小皮面板(phpstudy) 小皮下载地址 1选择windows 版本&#xff0c;点击立即下载 下载完成&#xff0c;进行解压&#xff0c;注意不要有中文路径 点击.exe文件进行安装…

AI数字人技术源码开发分享:革新短视频营销策略

集星幻影的AI数字人分身系统是一款融合了先进人工智能技术的综合性短视频营销解决方案。该系统整合了形象克隆、声音克隆、AI数字人分身生成、智能剪辑及文案创作等功能&#xff0c;旨在为用户打造虚拟人物资产并提供AI驱动的多模态交互服务。以下是该系统的主要功能概述&#…

Day 51 卡玛笔记

这是基于代码随想录的每日打卡 647. 回文子串 给你一个字符串 s &#xff0c;请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子字符串 是字符串中的由连续字符组成的一个序列。 示例 1&#xff1a; 输入&#xff1a;s &q…

ArcGIS Pro可见性分析:精通地形视线与视域分析

在地理信息系统&#xff08;GIS&#xff09;的广泛应用中&#xff0c;可见性分析作为一项关键技术&#xff0c;发挥着不可替代的作用。 无论是城市规划、环境监测&#xff0c;还是军事侦察、景观设计&#xff0c;可见性分析都能提供精确的数据支持&#xff0c;帮助我们更好地理…

【WSL2】 Ubuntu20.04 GUI图形化界面 VcXsrv ROS noetic Vscode 主机代理 配置

【WSL2】 Ubuntu20.04 GUI图形化界面 VcXsrv ROS noetic Vscode 主机代理 配置 前言整体思路安装 WSL2Windows 环境升级为 WIN11 专业版启用window子系统及虚拟化 安装WSL2通过 Windows 命令提示符安装 WSL安装所需的 Linux 发行版&#xff08;如 Ubuntu 20.04&#xff09;查看…

点云 Ubuntu20.04-VScode已解决fatal error: Eigen/StdVector: 没有那个文件或目录

原因&#xff1a;路径问题 。 解决&#xff1a;解决方法&#xff1a; 使用下面命令将eigen的安装路径映射到/usr/include路径下:pcl按照z方向渲染点云&#xff0c;但是CMakelists.txt编译找不到pcl/io/pcd_io.h: 没有那个文件或目录&#xff0c;Eigen找不到&#xff0c;open3d…

Redis 面试

Redis 使用场景有哪些&#xff1f; 缓存&#xff1a;缓存热点数据&#xff0c;如数据库查询结果、页面片段等&#xff0c;减少数据库压力&#xff0c;提高系统响应速度。 分布式锁&#xff1a;利用 Redis 的原子操作实现分布式锁&#xff0c;保证在分布式环境下同一时刻只有一…

228页PPT丨制造业核心业务流程优化咨询全案(战略营销计划生产研发质量),附核心系统集成架构技术支撑体系,2月26日资料已更新

一、订单全生命周期管理优化 1. 智能订单承诺&#xff08;CTP&#xff09;系统 ●集成ERP/APS/MES数据&#xff0c;实时计算产能可视性 ●应用蒙特卡洛模拟评估订单交付风险 ●建立动态插单评估模型&#xff08;基于边际贡献与产能占用系数&#xff09; 2. 跨部门协同机制…

mysql5.7离线安装及问题解决

这次主要是讲解mysql5.7离线安装教程和一主一从数据库配置 1、去官网下载自己对应的mysql https://downloads.mysql.com/archives/community/2、查看需要安装mysql服务器的linux的类型 uname -a第二步看一下系统有没有安装mysql rpm -qa|grep -i mysql3、上传安装包 用远程…

AI人工智能机器学习之聚类分析

1、概要 本篇学习AI人工智能机器学习之聚类分析&#xff0c;以KMeans、AgglomerativeClustering、DBSCAN为例&#xff0c;从代码层面讲述机器学习中的聚类分析。 2、聚类分析 - 简介 聚类分析是一种无监督学习的方法&#xff0c;用于将数据集中的样本划分为不同的组&#xff…

springai系列(二)从0开始搭建和接入azure-openai实现智能问答

文章目录 前言1.从0开始搭建项目2.进入微软openai申请key3.配置application.yaml4.编写controller5.测试源码下载地址总结 前言 之前使用openai的官网的api需要科学上网&#xff0c;但是我们可以使用其他的代理间接实现使用chatgpt的相关模型&#xff0c;解决这个问题。比如:本…

2020年蓝桥杯Java B组第二场题目+部分个人解析

#A&#xff1a;门牌制作 624 解一&#xff1a; public static void main(String[] args) {int count0;for(int i1;i<2020;i) {int ni;while(n>0) {if(n%102) {count;}n/10;}}System.out.println(count);} 解二&#xff1a; public static void main(String[] args) {…

DeepSeek 202502 开源周合集

DeepSeek 本周的开源项目体现了其在 AI 技术栈中的深厚积累&#xff0c;从硬件协同优化&#xff08;FlashMLA&#xff09;、通信库&#xff08;DeepEP&#xff09;、核心计算&#xff08;DeepGEMM&#xff09;到推理模型&#xff08;DeepSeek-R1&#xff09;&#xff0c;覆盖了…