深拷贝与浅拷贝的区别是什么?如何实现深拷贝?

深拷贝会递归复制对象所有嵌套属性,确保新旧对象完全独立,而浅拷贝仅复制引用,导致修改相互影响;常用深拷贝方法包括JSON.parse(JSON.stringify(obj))、递归函数处理循环引用和特殊对象,或使用Lodash的_.cloneDeep()及现代API structuredClone()。

深拷贝与浅拷贝的区别是什么?如何实现深拷贝?

浅拷贝仅仅是复制了对象或数组的引用,这意味着新旧变量指向的是内存中的同一块数据,当其中一个修改了内部的复杂类型(比如另一个对象或数组)时,另一个也会随之改变。而深拷贝则不然,它会递归地复制所有嵌套的属性,确保新旧对象在内存中拥有完全独立的存储空间,彼此互不影响。实现深拷贝,通常需要根据对象的结构,逐层、逐属性地进行复制,尤其要关注那些引用类型的数据。

解决方案

理解深拷贝与浅拷贝的核心在于它们对“引用”的处理方式。浅拷贝在遇到对象内部的引用类型属性时,只会复制这个引用本身,而不是引用所指向的实际数据。这就好比你复制了一个文件的快捷方式,而不是文件本身。你通过快捷方式修改了文件内容,原文件自然也变了。深拷贝则不同,它会深入到每一个引用类型属性的内部,将其指向的数据也完整地复制一份,直到所有数据都是原始类型(如数字、字符串、布尔值)为止。这就像你把整个文件都复制了一遍,新旧文件完全独立。

要实现深拷贝,在JavaScript中,最简单粗暴但也最常用的方法是利用

JSON.parse(JSON.stringify(obj))

。这种方法利用了JSON序列化和反序列化的过程,将对象转换为字符串再解析回来,从而切断了所有引用。但需要注意的是,这种方法有其局限性,比如无法处理函数、

undefined

Date

对象(会被转换为字符串)、

RegExp

对象,以及最关键的——循环引用。对于更复杂的情况,我们通常需要编写递归函数,或者借助成熟的第三方库。

浅拷贝的陷阱与潜在风险:为什么理解其行为至关重要?

说实话,我个人在开发中就遇到过好几次因为没搞清楚浅拷贝而引发的“血案”。最典型的场景就是当你从一个配置对象中取出一个子对象,然后直接修改它,结果发现原始的配置对象也跟着变了,这在调试时简直是灾难。

想象一下,你有一个用户设置对象,里面包含一个

theme

子对象,存储着颜色偏好等。如果你只是简单地通过

Object.assign()

或者展开运算符

{...userSettings}

来复制

userSettings

,那么

theme

这个属性其实只是复制了引用。当你尝试修改

copiedSettings.theme.primaryColor = 'blue'

时,原

userSettings.theme.primaryColor

也变成了

blue

。这种隐式修改往往发生在不经意间,尤其是在组件之间传递props,或者在状态管理中处理不可变数据时,如果使用了浅拷贝,就很容易导致数据污染,或者触发不必要的重新渲染。

这种行为模式,尤其在处理数组嵌套对象时,更让人头疼。比如一个包含多个商品对象的购物车数组,如果你浅拷贝了这个数组,然后修改了其中一个商品的某个属性,那么原始购物车数组里的那个商品也会被修改。这不仅影响了数据的纯洁性,也让程序的行为变得难以预测和维护。理解浅拷贝的本质,是避免这些潜在风险的第一步。

实现深拷贝的策略与考量:从简单到复杂

实现深拷贝,方法多种多样,选择哪种取决于你的具体需求和要处理的数据复杂性。

最简单直接的,正如前面提到的,是

JSON.parse(JSON.stringify(obj))

。它的优点是代码简洁,易于理解,对于只包含数字、字符串、布尔值、null以及普通对象和数组的纯数据对象,它工作得很好。但缺点也同样明显,它会丢失函数、

undefined

Symbol

BigInt

等类型,并且会将

Date

对象转换为ISO格式的字符串,

RegExp

对象会变成空对象。更重要的是,它无法处理循环引用,一旦对象内部存在相互引用的情况,它会直接抛出错误。我个人在处理一些简单的API响应数据时,会图方便用它,但只要数据结构稍微复杂一点,就得另寻他法了。

阿贝智能 阿贝智能

阿贝智能是基于AI技术辅助创作儿童绘本、睡前故事和有声书的平台,助你创意实现、梦想成真。

阿贝智能 17 查看详情 阿贝智能

JSON

方法不够用时,我们通常会考虑手写一个递归函数。这需要我们遍历对象的每一个属性,判断其类型。如果是原始类型,直接赋值;如果是对象或数组,则递归调用自身。这里有一个基本的JavaScript实现思路:

function deepClone(obj, hash = new WeakMap()) {  if (obj === null || typeof obj !== 'object') {    return obj;  }  // 处理循环引用  if (hash.has(obj)) {    return hash.get(obj);  }  let cloneObj;  // 处理日期对象  if (obj instanceof Date) {    cloneObj = new Date(obj);  }   // 处理正则表达式  else if (obj instanceof RegExp) {    cloneObj = new RegExp(obj);  }  // 处理Map、Set等其他特殊对象  // else if (obj instanceof Map) { ... }  // else if (obj instanceof Set) { ... }  // ...  else {    cloneObj = Array.isArray(obj) ? [] : {};  }  hash.set(obj, cloneObj); // 存储已克隆的对象,防止循环引用  for (let key in obj) {    // 确保只复制对象自身的属性,不包括原型链上的    if (Object.prototype.hasOwnProperty.call(obj, key)) {      cloneObj[key] = deepClone(obj[key], hash);    }  }  return cloneObj;}

这个递归函数需要考虑很多细节,比如如何处理

Date

RegExp

Map

Set

等内置对象,以及如何优雅地处理原型链上的属性。最重要的是,它需要一个机制来处理循环引用,否则会陷入无限循环。上面代码中的

WeakMap

就是用来记录已经访问过的对象,避免重复克隆和处理循环引用的。

对于更健壮和全面的深拷贝,很多时候我们会选择使用成熟的第三方库,比如Lodash的

_.cloneDeep()

。这些库经过了大量的测试和优化,能够处理各种复杂的边缘情况,包括循环引用、特殊对象类型、不可枚举属性等,用起来省心省力。在生产环境中,如果不是对性能有极致要求且能精准控制数据结构,我个人更倾向于使用这样的库。

优化深拷贝性能与应对特殊场景:循环引用与特殊对象

深拷贝并非没有代价,尤其是在处理大型或深度嵌套的对象时,其性能开销是需要考虑的。

JSON.parse(JSON.stringify(obj))

虽然代码简洁,但其内部的序列化和反序列化过程本身就是耗时操作,对于超大对象,性能瓶颈会非常明显。手写递归函数虽然灵活,但如果实现不当,也可能效率低下。

循环引用是一个深拷贝的经典难题。当一个对象A引用了对象B,而对象B又引用了对象A时,就形成了循环引用。如果深拷贝函数没有处理机制,它会无限递归下去,最终导致栈溢出。前面提到的

WeakMap

Map

就是解决这个问题的有效方法:在克隆一个对象之前,先检查它是否已经被克隆过。如果已经克隆过,就直接返回之前克隆的副本,而不是再次递归。这就像给每个已经处理过的对象打上一个“已访问”的标记。

特殊对象的处理也是深拷贝的另一个难点。除了前面提到的

Date

RegExp

,还有

Map

Set

Promise

Error

对象,甚至自定义类的实例。一个通用的深拷贝函数需要针对这些类型进行专门的判断和处理。例如,对于

Map

Set

,需要遍历它们的成员并递归克隆;对于函数,通常是直接复制引用(因为函数是行为,而非数据,深拷贝函数本身意义不大);对于自定义类的实例,可能需要调用其构造函数并逐一复制属性,甚至考虑原型链上的属性。

值得一提的是,现代浏览器和Node.js环境中,已经有了

structuredClone()

这个API,它实现了结构化克隆算法,能够非常高效且正确地处理大部分复杂类型,包括循环引用、

Date

RegExp

Map

Set

ArrayBuffer

等。如果你的目标环境支持这个API,那无疑是实现深拷贝的最佳选择,它比手写递归函数更健壮,比

JSON

方法更全面,性能也通常更好。当然,对于一些老旧环境的兼容性考虑,手动实现或引入第三方库依然是必要的。

以上就是深拷贝与浅拷贝的区别是什么?如何实现深拷贝?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/215706.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 14:43:47
下一篇 2025年11月3日 14:44:26

相关推荐

  • 易欧OKX安卓客户端安装 2025官方v6.128.1版本交易平台

    易欧okx是一款全球领先的数字资产服务平台,致力于为广大用户提供安全、稳定、可靠的数字资产交易服务。平台支持多种主流数字资产的交易,并提供多样化的交易工具和产品,满足从新手到专业交易者的不同需求。本文为您提供了易欧okx官方app的下载渠道,点击本文中提供的官方下载链接,即可轻松获取并安装最新版本的…

    好文分享 2025年12月11日
    000
  • 数字货币app安卓版2025最新地址 虚拟货币app官方版安装包

    一款功能强大、安全可靠的数字货币app,它不仅能让您随时随地查看各种数字货币的实时价格与历史K线,还能轻松进行交易操作。这款专为安卓用户打造的虚拟货币App,将成为您驰骋数字世界的得力助手,让您轻松管理数字资产,不错过任何投资良机。 为了方便广大用户,本文为您整理了2025年最新的官方版安装包获取方…

    2025年12月11日
    000
  • 以太坊价格走势实时追踪 ETH最新app行情图一键查

    随着区块链技术的飞速发展,数字货币已不再是遥远的未来概念,而是深刻影响我们数字生活的重要组成部分。从比特币的开创性到以太坊的生态繁荣,再到无数创新币种的涌现,这个充满活力的市场正以前所未有的速度扩张。我们的官方app,正是您驾驭这场数字财富之旅的得力助手。它不仅能让您随时随地洞察市场脉搏,更提供便捷…

    2025年12月11日 好文分享
    000
  • 虚拟货币app最新版正版 数字货币app安卓版安装包

    您是否渴望在瞬息万变的数字货币市场中抢占先机?想要一个能随时随地掌握行情、轻松完成交易的强大工具吗?这款全新的数字货币app将是您的理想选择,它集实时行情、深度图表与便捷交易于一体,不仅可以查看各种数字货币实时价格与历史价格,还能进行各种数字货币交易,助您轻松驾驭数字资产的世界。 为了确保您获得的是…

    2025年12月11日
    000
  • 币安App官方下载入口【最新版本v3.0.4】|合约杠杆一站式管理

    币安(binance)是全球领先的数字资产交易平台,提供现货、合约、杠杆、理财等多种功能。为了保障账户和资金安全,建议通过官方渠道下载并安装最新版 app。 官网链接: 最新版客户端下载地址: 1. 如何确认访问的是币安正版官网 请确保网址以https://www.binance.com或 http…

    2025年12月11日
    000
  • 欧易OKX正规平台登录官网地址推荐

    欧易(okx)是全球领先的数字资产交易平台之一,提供现货、合约、杠杆、理财等多种功能。为了保障账户和资金安全,建议通过官方渠道登录平台。 官网链接: 客户端下载地址: 1. 如何确认访问的是欧易正版官网 请确保网址以https://www.okx.com或https://www.ouxyi.com开…

    2025年12月11日
    000
  • 欧易OKX安卓最新版下载|官方正版App v6.130.1安装指南

    欧易(okx)是全球领先的数字资产交易平台之一,提供现货、合约、杠杆、理财等多种功能。为了保障账户和资金安全,建议通过官方渠道下载并安装最新版 app。 官网链接: 客户端下载地址: 1. 如何确认访问的是欧易正版官网 请确保网址以https://www.okx.com或https://www.ou…

    2025年12月11日
    000
  • Gate.io芝麻开门官网地址+官方app注册教程(最新版本)

    gate.io(芝麻开门)是全球领先的数字资产交易平台之一,提供现货、合约、杠杆、理财等多种功能。为了保障账户和资金安全,建议通过官方渠道注册并下载app。 官网链接: 客户端下载地址: 1. 如何确认访问的是 Gate.io 正版官网 请确保网址以https://www.gate.io或https…

    2025年12月11日
    000
  • 火币HTX全球站官网注册地址(最新版App支持)

    火币htx(原名火币网)是全球领先的数字资产交易平台之一,提供现货、合约、杠杆、理财等多种功能。为了保障账户和资金安全,建议通过官方渠道注册并下载app。 官网注册链接: App下载地址: 1. 如何确认访问的是火币HTX正版官网 请确保网址以https://www.htx.com开头,并注意浏览器…

    2025年12月11日
    000
  • 以太坊、加密货币与市场动态:究竟发生了什么?

    以太坊gas上限上调,xrp、solana与狗狗币强势一周,以及柴犬币的销毁机制。带你掌握加密货币市场的最新变化。 以太坊、加密资产与市场趋势:到底发生了哪些变化? 加密货币市场持续波动,近期以太坊及其他数字资产出现了值得关注的动态。我们一起来看看最新的市场走势,并分析其背后的原因。 以太坊Gas上…

    2025年12月11日
    000
  • 数字货币怎么玩 数字货币有哪些 数字货币交易平台

    数字货币是基于区块链技术的数字资产,具有去中心化、匿名性、全球流通和高安全性等特点。1. 主流数字货币包括比特币(BTC)、以太坊(ETH)、泰达币(USDT)、瑞波币(XRP)、莱特币(LTC)、波卡(DOT)和狗狗币(DOGE)等,各自具备不同的技术特性和应用场景。2. 参与数字货币的方式包括学…

    2025年12月11日 好文分享
    000
  • 数字货币是加密货币吗

    数字货币与加密货币的关系是包含但不等同,加密货币是数字货币的一个特殊子集。数字货币是一个广义术语,涵盖所有以电子形式存在的货币,包括中央银行数字货币、电子货币和加密货币;而加密货币是基于密码学和区块链技术的去中心化数字资产,如比特币和以太坊。两者在发行机制上存在根本差异:数字货币通常由中央机构发行和…

    2025年12月11日
    000
  • 币安安卓最新版v3.0.4下载 币安app中文版安装教程

    币安(binance)是全球领先的数字资产交易平台之一,提供现货、合约、理财等多种功能。由于政策限制,大陆用户无法直接在google play或国内应用市场下载币安app,因此需要通过官方渠道获取apk安装包。以下是最新版本v3.0.4的下载与安装教程,帮助您顺利体验币安app中文版。 官网链接: …

    2025年12月11日 好文分享
    000
  • BlockDAG:无需锁仓的加密货币买入——一场变革?

    blockdag 的“无锁仓通行证”正在引发加密预售市场的震动,为投资者带来即时流动性与自主控制权。这是否会成为加密投资的新方向? BlockDAG:购币无需锁定?加密领域的一次重大革新? 围绕 BlockDAG 推出的“无锁仓通行证”(NO VESTING PASS)的讨论热度持续上升。试想一下,…

    2025年12月11日
    000
  • FloppyPepe:2025年在Solana上展现实用性的模因币

    忘记短暂的炒作吧!floppypepe(fppe)在 solana 上将模因魔力与创作者工具结合,正成为有望实现百倍增长的有力竞争者。这会是下一个模因传奇吗? 加密市场的模因币狂热远未结束,但规则正在改变。Solana 充满活力的生态系统正在孕育新一代模因币,而 FloppyPepe(FPPE)正引…

    2025年12月11日
    000
  • MoonBull:通往迷因币狂潮和早期财富的白名单通行证

    moonbull 白名单已成为 meme 币圈最抢手的通行证,提供早期访问权限、神秘奖励,以及实现千倍收益的可能。这波牛市,你怎能缺席? meme 币市场正以惊人的速度扩张,新项目不断涌现,快得让你还没喊出“HODL”,就已经错过了下一个机会。如今,整个圈子都在谈论一个关键词:MoonBull 白名…

    2025年12月11日
    000
  • BlockDAG、OpenFundNet 与实用区块链革命

    探索 blockdag、openfundnet 与实用型区块链运动如何推动加密货币从投机转向实际应用和建设者为中心的生态系统 BlockDAG、OpenFundNet 与实用型区块链的革新之路 加密货币行业正在快速转型,逐步摆脱以炒作为主的阶段,迈向以实际应用为核心的新纪元。BlockDAG、Ope…

    2025年12月11日
    000
  • XRP、狗狗币与加密货币投资回报率:超越炒作

    穿越加密世界:xrp的韧性、狗狗币的财库提振,以及lilpepe等新晋代币带来的高回报诱惑 加密货币市场始终充满活力。XRP展现出了其持久的生命力,狗狗币(Dogecoin)迎来了5亿美元的资金注入,而投资者们也都在寻找下一个能带来高回报的投资标的。让我们深入看看。 XRP:重拾辉煌的可能? 你还记…

    2025年12月11日
    000
  • 加密货币牛人狂潮:在模因币的狂野西部追逐1000倍增长

    深入解析迷因币热潮:moonbull、turbo 与 bome,揭开千倍增长潜力与社区创新的面纱 加密货币市场正掀起一场风暴,朋友们!别再关注华尔街那些西装革履的精英了,今天我们聚焦的是迷因币、登月项目,以及“加密、MoonBull、千倍回报”的狂热承诺。这是一场数字时代的淘金热潮,每个人都渴望一夜…

    2025年12月11日
    000
  • 比特币、巨鲸与币安:解读市场动向

    比特币巨鲸与币安的近期交易深度解析:市场趋势与投资策略展望 比特币、巨鲸与币安:解读市场动向 你是否曾好奇那些巨额比特币交易对我们普通投资者意味着什么?本文将深入分析近期币安平台上的巨鲸动向,并探讨其对加密货币市场的信号意义。 巨鲸警报:1300万美元比特币转账至币安 近日,一位比特币巨鲸将其在过去…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信