登录
首页 >  文章 >  前端

浅副本和深副本

时间:2025-02-11 19:55:19 423浏览 收藏

小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《浅副本和深副本》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

浅拷贝与深拷贝:JavaScript 对象复制详解

本文深入探讨 JavaScript 中的浅拷贝和深拷贝,并通过示例代码清晰地展现两者之间的差异。理解这两种拷贝方式对于避免潜在的程序错误至关重要。

1. 浅拷贝

浅拷贝创建一个新对象,但只复制顶层属性。对于嵌套对象或数组,浅拷贝只复制其引用,而非创建新的副本。这意味着,修改浅拷贝中的嵌套对象会同时影响原始对象。

示例 1:使用 Object.assign() 进行浅拷贝

const original = {
  name: "john",
  age: 30,
  address: {
    city: "new york",
    zip: "10001"
  }
};

const deepCopy = JSON.parse(JSON.stringify(original));

deepCopy.address.city = "los angeles";

console.log(original.address.city); // 输出: "new york"
console.log(deepCopy.address.city); // 输出: "los angeles"

说明: JSON.stringify() 将对象转换为 JSON 字符串,JSON.parse() 将 JSON 字符串解析回新的对象。这创建了一个完全独立的副本。

深拷贝与浅拷贝的差异:

特性 浅拷贝 深拷贝
速度
内存占用
嵌套对象/数组 只复制引用,修改会影响原始对象 创建新的副本,修改不会影响原始对象
适用场景 简单的对象复制,性能要求高的情况 复杂的嵌套对象,需要完全独立的副本的情况
局限性 无法复制函数、日期等特殊对象类型 JSON.parse(JSON.stringify()) 无法处理函数、正则表达式、Date 对象等

警告: 使用 JSON.parse(JSON.stringify()) 进行深拷贝的局限性:

  • 它不能复制函数、undefined、正则表达式、Date 对象或循环引用。
  • 它可能无法保留特殊对象类型(例如,MapSet)。

对于更复杂的深拷贝需求,建议使用 Lodash 的 _.cloneDeep() 等工具函数。

浅副本和深副本

选择浅拷贝还是深拷贝取决于具体的应用场景。如果只需要复制简单的对象,并且性能是关键因素,那么浅拷贝是合适的。如果需要完全独立的副本,并且可以承受一定的性能损耗,那么深拷贝是更好的选择。

以上就是《浅副本和深副本》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>