当前位置: 首页 > news >正文

做的比较好的卡车网站桂林网上商城

做的比较好的卡车网站,桂林网上商城,wordpress手机qq登录地址,朔州推广型网站建设递归深度拷贝情况一&#xff1a;基本数据类型&#xff0c;直接赋值情况二&#xff1a;复杂数据类型&#xff08;数组和对象&#xff09;先声明空容器&#xff0c;再递归调用遍历赋值情况三&#xff1a;正则表达式&#xff0c;日期对象等<!DOCTYPE html> <html lang&qu…

递归深度拷贝

情况一:基本数据类型,直接赋值

情况二:复杂数据类型(数组和对象)先声明空容器,再递归调用遍历赋值

情况三:正则表达式,日期对象等

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>深度拷贝示例</title>
</head>
<body><script>function deepCopy(target, source, map = new WeakMap()) {if (source === null) {return null;}if (typeof source !== 'object') {return source;}if (map.has(source)) {return map.get(source);}let clone;if (source instanceof Date) {clone = new Date(source.getTime());map.set(source, clone);return clone;}if (source instanceof RegExp) {clone = new RegExp(source);map.set(source, clone);return clone;}if (Array.isArray(source)) {clone = [];map.set(source, clone);source.forEach((item, index) => {clone[index] = deepCopy(null, item, map);});return clone;}clone = {};map.set(source, clone);Object.keys(source).forEach(key => {clone[key] = deepCopy(null, source[key], map);});return clone;}const original = {name: "张三",age: 30,isStudent: false,hobby: null,skills: ["JavaScript", "React", "Node.js"],contact: {phone: "13800138000",email: "zhangsan@example.com"},birthday: new Date("1990-01-01"),regex: /\d+/g,self: null};original.self = original;const clone = deepCopy(null, original);clone.age = 31;clone.skills.push("Vue");clone.contact.phone = "13900139000";clone.birthday.setFullYear(1991);console.log("原始对象:", original);console.log("克隆对象:", clone);console.log("克隆对象是否等于原始对象:", clone === original);console.log("克隆对象的self属性是否指向自身:", clone.self === clone);</script>
</body>
</html>

函数递归地复制对象及其嵌套属性,确保原始对象和克隆对象完全独立。它处理了多种数据类型和循环引用的情况。

function deepCopy(target, source, map = new WeakMap()) {// 处理 null 值if (source === null) {return null;}// 处理原始数据类型(非对象)if (typeof source !== 'object') {return source;}// 处理循环引用:如果已复制过该对象,直接返回之前的克隆if (map.has(source)) {return map.get(source);}let clone;// 处理日期对象if (source instanceof Date) {clone = new Date(source.getTime());map.set(source, clone);return clone;}// 处理正则表达式对象if (source instanceof RegExp) {clone = new RegExp(source);map.set(source, clone);return clone;}// 处理数组if (Array.isArray(source)) {clone = [];map.set(source, clone);source.forEach((item, index) => {clone[index] = deepCopy(null, item, map);});return clone;}// 处理普通对象clone = {};map.set(source, clone);Object.keys(source).forEach(key => {clone[key] = deepCopy(null, source[key], map);});return clone;
}

处理策略说明

  1. 原始值处理:直接返回原值,不进行复制。
  2. 对象类型处理
    • 日期对象:创建新的日期对象,使用相同的时间戳。
    • 正则表达式:创建新的正则对象,使用相同的模式和标志。
    • 数组:创建新数组,递归复制每个元素。
    • 普通对象:创建新对象,递归复制每个自有属性。
  3. 循环引用处理:使用 WeakMap 记录已处理的对象,避免无限递归。

测试对象 original

代码创建了一个包含多种数据类型的复杂对象,并设置了循环引用:

const original = {name: "张三",           // 字符串age: 30,               // 数字isStudent: false,      // 布尔值hobby: null,           // nullskills: ["JavaScript", "React", "Node.js"],  // 数组contact: {             // 嵌套对象phone: "13800138000",email: "zhangsan@example.com"},birthday: new Date("1990-01-01"),  // 日期对象regex: /\d+/g,                     // 正则表达式self: null                         // 用于循环引用
};
// 设置循环引用:self 属性指向对象自身
original.self = original;

深度拷贝测试

const clone = deepCopy(null, original);
// 修改克隆对象的属性
clone.age = 31;
clone.skills.push("Vue");
clone.contact.phone = "13900139000";
clone.birthday.setFullYear(1991);// 输出测试结果
console.log("原始对象:", original);
console.log("克隆对象:", clone);
console.log("克隆对象是否等于原始对象:", clone === original);
console.log("克隆对象的self属性是否指向自身:", clone.self === clone);

关键测试点

  1. 完全独立:修改克隆对象不会影响原始对象,反之亦然。
  2. 循环引用处理:克隆对象的 self 属性正确指向克隆对象自身,而非原始对象。
  3. 嵌套结构保持:所有嵌套对象都被递归复制,保持相同的结构。
http://www.dtcms.com/a/557288.html

相关文章:

  • 营销建设网站制作浙江软装设计公司
  • MIP与VR:医学影像处理与虚拟现实技术详解
  • 如何用虚拟主机建设网站房地产项目网站建设
  • 快速上手大模型:深度学习3(实践:线性神经网络Softmax)
  • 网站 标准规划电子商务网站建设方案
  • 阻塞队列(BlockingQueue)原理、实现与应用:多线程编程中的核心数据结构
  • mstscax!CCC::CCFSMProc调试记录设置为1打开调试开关
  • 树莓派连接海康威视工业相机
  • 建设家具网站手机端怎么看世界杯
  • Go语言设计模式:工厂模式详解
  • Docker 部署 openEuler 教程及常见问题解决
  • 厦门专业做网站 厦门做网站的公司 厦门做服饰网站网站开发程序员需要会的技能
  • W55MH32三模自由控:小程序按键网页随选
  • 物联网入侵检测技术综合综述报告
  • 大模型-Qwen-Agent框架:系列Agent功能介绍 (2)
  • 网站 设计理念淄博网站建设优化运营熊掌号
  • R 包的制作
  • 【矩阵分析与应用】【第5章 梯度分析与最优化】【5.2.2 矩阵迹的微分计算示例d(tr(U))=tr(dU)证明】
  • 岳阳网站设计公司网站开发意义
  • MySQL的CONCAT函数介绍
  • 潜山云建站网站建设wordpress获取当前用户id
  • makefile 函数全解
  • day01_牛客_数字统计_C++
  • Redis RDB 持久化机制深入理解:Copy-On-Write 与数据一致性保障
  • 做哪方面的网站阳泉哪里做网站
  • 电商网站改版方案有哪些免费的ppt模板下载网站
  • LeetCode 3217.从链表中移除在数组中存在的节点:哈希表(一次遍历)
  • LeetCode - 寻找两个正序数组的中位数
  • 上海网站设计公司 静安沙井建网站
  • VMware17完成克隆ubuntu20.04时IP地址相同的问题