对象的深度拷贝(转)

原:http://www.e-snowlife.com/?p=272
对象的深度拷贝方法,在应用中经常需要传递一个对象参数,传递过去的对象的修改又不希望对原对象产生影响,用该对象方法可以轻松实现了

代码:

package {
import flash.utils.ByteArray;
import flash.utils.getQualifiedClassName;
import flash.utils.getDefinitionByName;
import flash.net.registerClassAlias;

public class CopyUtil{
public static function clone(object:Object):Object{
var qClassName:String = getQualifiedClassName(object);
var objectType:Class = getDefinitionByName(qClassName) as Class;
registerClassAlias(qClassName, objectType);
var copier : ByteArray = new ByteArray();
copier.writeObject(object);
copier.position = 0;
return copier.readObject();
}
}
}

 

使用方法:

代码:

var instanceA : ClassA = new ClassA(); 
var instanceCopy : ClassA = CopyUtil.clone(instanceA ) as ClassA; 
trace(instanceCopy == instanceA)//fale; 
trace(instanceCopy is ClassA) // true; 
trace(instanceCopy is superClass) //true; 

 

 

在 JavaScript 中,如果直接将一个对象赋值给另一个变量,那么它们将共享同一个对象,也就是说它们指向同一个内存地址。这种情况下,修改其中一个变量的属性或者方法,将会影响到另一个变量。为了避免这种情况,可以使用深度拷贝来创建一个新的对象,从而避免共享内存地址的问题。 以下是一些实现深度拷贝的方法: 1. 使用 JSON.parse 和 JSON.stringify 这种方法可以将对象换为 JSON 字符串,然后再将 JSON 字符串换为新的对象,这样就可以创建一个与原对象完全独立的新对象。但是,这种方法有一些限制,例如无法拷贝函数、正则表达式等。 ```javascript const obj = {a: 1, b: {c: 2}}; const newObj = JSON.parse(JSON.stringify(obj)); console.log(newObj); // 输出 {a: 1, b: {c: 2}} ``` 2. 递归拷贝 这种方法可以遍历对象的所有属性和方法,创建一个新的对象,并将原对象的属性和方法复制到新对象中。如果属性值是对象或者数组,那么递归调用拷贝函数来创建一个新的对象或者数组。 ```javascript function deepCopy(obj) { if (typeof obj !== 'object' || obj === null) { return obj; } const newObj = Array.isArray(obj) ? [] : {}; for (let key in obj) { newObj[key] = deepCopy(obj[key]); } return newObj; } const obj = {a: 1, b: {c: 2}}; const newObj = deepCopy(obj); console.log(newObj); // 输出 {a: 1, b: {c: 2}} ``` 通过以上两种方法,可以实现深度拷贝对象。需要注意的是,如果对象中包含循环引用,那么以上两种方法都会出现栈溢出的问题,需要进行特殊处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值