深拷贝和浅拷贝笔记

浅拷贝

只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存。

  • 新旧对象共享内存,修改其中一个则会影响另外一个,则为浅拷贝;
1、直接遍历

数组

var array = [1, 2, 3, 4];
function copy (array) {
   let newArray = []
   for(let item of array) {
      newArray.push(item);
   }
   return  newArray;
}
var copyArray = copy(array);
copyArray[0] = 100;
console.log(array); // [1, 2, 3, 4]
console.log(copyArray); // [100, 2, 3, 4]

对象

function clone(obj) {
  if (obj == null || typeof obj !== 'object') return obj
  var newObj = Array.isArray(obj) ? [] : {}
  for (let i in obj) {
    if (obj.hasOwnProperty(i)) {
      newObj[i] =obj[i]
    }
  }
  return newObj
}

#####2、array.slice(start,end)
返回一个从已有的数组中截取一部分元素片段组成的新数组(不改变原来的数组!)
start表示是起始元素的下标, end表示的是终止元素的下标(不包括end)
当slice()不带任何参数的时候,默认返回一个长度和原数组相同的新数组

var array = [1, 2, 3, 4];
var copyArray = array.slice();
copyArray[0] = 100;
console.log(array); // [1, 2, 3, 4]
console.log(copyArray); // [100, 2, 3, 4]
3、concat()

concat() 方法用于连接两个或多个数组。( 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。)
用法:array.concat(array1,array2,…,arrayN)
不带参数array.concat()相当于array.concat([])

var array = [1, 2, 3, 4];
var copyArray = array.concat();
copyArray[0] = 100;
console.log(array); // [1, 2, 3, 4]
console.log(copyArray); // [100, 2, 3, 4]
4、Object.assign
var obj2 = Object.assign({}, obj)

深拷贝

会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。

  • 新旧对象不共享内存,修改其中一个不会影响另一个,则为深拷贝。
1、递归复制
//实现深拷贝函数
function deepClone(data) {
    const type = this.judgeType(data);
    let obj = null;
    if (type == 'array') {
        obj = [];
        for (let i = 0; i < data.length; i++) {
            obj.push(this.deepClone(data[i]));
        }
    } else if (type == 'object') {
        obj = {}
        for (let key in data) {
            if (data.hasOwnProperty(key)) {
                obj[key] = this.deepClone(data[key]);
            }
        }
    } else {
        return data;
    }
    return obj;
}

function judgeType(obj) {
    // tostring会返回对应不同的标签的构造函数
    const toString = Object.prototype.toString;
    const map = {
        '[object Boolean]': 'boolean',
        '[object Number]': 'number',
        '[object String]': 'string',
        '[object Function]': 'function',
        '[object Array]': 'array',
        '[object Date]': 'date',
        '[object RegExp]': 'regExp',
        '[object Undefined]': 'undefined',
        '[object Null]': 'null',
        '[object Object]': 'object',
    };
    if (obj instanceof Element) {
        return 'element';
    }
    return map[toString.call(obj)];
}
2、JSON.parse(JSON.stringify(obj))实现
let objClone = JSON.parse(JSON.stringify(obj))

弊端:

  • 1)、如果obj里面存在时间对象,JSON.parse(JSON.stringify(obj))之后,时间对象变成了字符串。
  • 2)、如果obj里有RegExp、Error对象,则序列化的结果将只得到空对象。
  • 3)、如果obj里有函数,undefined,则序列化的结果会把函数, undefined丢失。
  • 4)、如果obj里有NaN、Infinity和-Infinity,则序列化的结果会变成null。
  • 5)、JSON.stringify()只能序列化对象的可枚举的自有属性。如果obj中的对象是有构造函数生成的,则使用JSON.parse(JSON.stringify(obj))深拷贝后,会丢弃对象的constructor。
  • 6)、如果对象中存在循环引用的情况也无法正确实现深拷贝。
3、JQ的extend方法

$.extend( [deep ], target, object1 [, objectN ] )
deep表示是否深拷贝,为true为深拷贝,为false,则为浅拷贝
target Object类型 目标对象,其他对象的成员属性将被附加到该对象上。
object1 objectN可选。 Object类型 第一个以及第N个被合并的对象。

let objClone = $.extend(true,{},obj);
4、lodash的_.cloneDeep
var _ = require('lodash')
let objClone = _.cloneDeep(obj)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在SystemVerilog中,深拷贝浅拷贝是指在复制对象时是否复制对象的内容。 浅拷贝是指仅复制对象的引用,而不复制对象的内容。当进行浅拷贝时,源对象和目标对象将指向同一个内存位置。如果修改了其中一个对象的内容,另一个对象也会受到影响。例如,在SV中,如果复制一个包含句柄的类对象,那么句柄将被复制,但实际对象不会被复制。这意味着修改其中一个对象的属性将影响另一个对象的属性。 深拷贝是指复制对象的内容和数据成员。在进行深拷贝时,每一个数据成员(包括嵌套的对象)都会被复制到新的对象中。这样,源对象和目标对象将拥有独立的内存空间,彼此之间的修改互不影响。在SV中,为了实现深拷贝,通常需要自定义`copy`函数来复制每一个数据成员。 需要注意的是,深拷贝可能会产生更多的内存开销,因为每个数据成员都需要复制。而浅拷贝则更加高效,因为只复制了引用。 综上所述,在SystemVerilog中,深拷贝浅拷贝是指复制对象时是否复制对象的内容。深拷贝会复制对象的内容和数据成员,而浅拷贝仅复制对象的引用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【sv中浅拷贝深拷贝】](https://blog.csdn.net/m0_56242485/article/details/123189393)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [SV学习笔记—浅复制和复制的区别详解](https://blog.csdn.net/qq_41337361/article/details/122845943)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值