Javascript 中 浅拷贝与深拷贝的实现

javascript

javascript中的对像赋值 与 Java中是一样的 ,都为引用传递.
就是说,在把一个对像赋值给一个变量时,那么这个变量所指向的仍就是原来对像的地址.那怎么来做呢 答案是 克隆.

什么是"clone"?

在实际编程过程中,我们常常要遇到这种情况:有一个对象A,在某一时刻A中已经包含了一些有效值,此时可能会需要一个和A完全相同新对象B,并且此后对B任何改动都不会影响到A中的值,也就是说,A与B是两个独立的对象,但B的初始值是由A对象确定的。在Java/javasript语言中,用简单的赋值语句是不能满足这种需求的。要满足这种需求虽然有很多途径,但实现clone()方法是其中最简单,也是最高效的手段,当然了 javascript语言中并没有此方法.

所以我特意写了两个克隆方法:一个为浅复制 ,一个为深复制.
解释:
浅复制(影子克隆):只复制对像的基本类型,对像类型,仍属于原来的引用.
深复制(深度克隆):不紧复制对象的基本类,同时也复制原对象中的 对像.就是说完全是新对象产生的.

下面是代码,我己测试过了,还没遇到什么问题 ,希望 大家感兴趣的 一起参与.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<META NAME="Generator" CONTENT="Wawa Editor 1.0">
<META NAME="Author" CONTENT="八神奄">
<META NAME="Keywords" CONTENT="javascript,Java,XML,XSLT,ASP,VBScript,ASP .net,C#,C++,Database">
<META NAME="Description" CONTENT="不及格的程序员,无所不在">
</HEAD>

<BODY>
<SCRIPT LANGUAGE="javascript">
<!--

function Object.prototype.clone(){
 var newObj = new Object();
 for(elements in this){
  newObj[elements] = this[elements];
 }
 return newObj;
}

function Object.prototype.cloneAll(){
 function clonePrototype(){}
 clonePrototype.prototype = this;
 var obj = new clonePrototype();
 for(var ele in obj){
  if(typeof(obj[ele])=="object") obj[ele] = obj[ele].cloneAll();
 }
 return obj;
}

 var obj1   = new Object();
 obj1.Team   = "First";
 obj1.Powers   = new Array("Iori","Kyo");
 obj1.msg   = function(){alert()};
 obj1.winner   = new Object();
 obj1.winner.name = obj1.Powers[0];
 obj1.winner.age  = 23;
 obj1.winner.from = "Japan"

 var obj1_clone   = obj1.cloneAll();
 obj1_clone.Team   = "Second";
 obj1_clone.Powers  = new Array("Jimmy","Anndy");
 obj1_clone.winner.name = obj1_clone.Powers[1];
 obj1_clone.winner.age = 22;
 obj1_clone.winner.from = "USA";

 msg  = "2003界拳皇单打独斗杯,拳皇挑战赛:  \n\n   A组 对战形式:\n\n"
 msg += obj1.Team+" 组 ,人员名单:"+obj1.Powers+"\n";
 msg += "第一轮过后,胜利者为:"+obj1.winner.name +" ,参赛者年龄:"+obj1.winner.age+" ,来自岛国: "+obj1.winner.from+"\n";
 msg += "\n\n   B组 对战形式:\n\n"
 msg += obj1_clone.Team+" 组 ,人员名单:"+obj1_clone.Powers+"\n";
 msg += "第一轮过后,胜利者为:"+obj1_clone.winner.name +" ,参赛者年龄:"+obj1_clone.winner.age+" ,来自国际警察部队: "+obj1_clone.winner.from+"\n";
 alert(msg);

//-->
</SCRIPT>
</BODY>
</HTML>

时间: 2025-01-30 08:29:47

Javascript 中 浅拷贝与深拷贝的实现的相关文章

javascript对浅拷贝和深拷贝的详解_基础知识

下面小编就为大家带来一篇浅谈JavaScript中面向对象的的深拷贝和浅拷贝.小编觉得挺不错的,现在就分享给大家,也给大家做个参考. 1.浅拷贝:复制一份引用,所有引用对象都指向一份数据,并且都可以修改这份数据. 2.深拷贝(复杂):复制变量值,对于非基本类型的变量,则递归至基本类型变量后,再复制. 这里画一个简单的图来加深理解: 一.数组的深浅拷贝 在使用JavaScript对数组进行操作的时候,我们经常需要将数组进行备份,事实证明如果只是简单的将它赋予其他变量,那么我们只要更改其中的任何一个

JavaScript中对象的深拷贝的详解

在JavaScript中,对对象进行拷贝的场景比较常见.但是简单的复制语句只能对对象进行浅拷贝,即复制的是一份引用,而不是它所引用的对象.而更多的时候,我们希望对对象进行深拷贝,避免原始对象被无意修改. 对象的深拷贝与浅拷贝的区别如下: 浅拷贝:仅仅复制对象的引用,而不是对象本身: 深拷贝:把复制的对象所引用的全部对象都复制一遍. 一. 浅拷贝的实现 浅拷贝的实现方法比较简单,只要使用是简单的复制语句即可. 1.1 方法一:简单的复制语句 /* ================ 浅拷贝 ====

JavaScript 中对象的深拷贝_javascript技巧

对象的深拷贝与浅拷贝的区别如下: 浅拷贝:仅仅复制对象的引用,而不是对象本身: 深拷贝:把复制的对象所引用的全部对象都复制一遍. 一. 浅拷贝的实现 浅拷贝的实现方法比较简单,只要使用是简单的复制语句即可. 1.1 方法一:简单的复制语句 /* ================ 浅拷贝 ================ */ function simpleClone(initalObj) {     var obj = {};     for ( var i in initalObj) {   

浅谈JavaScript中面向对象的的深拷贝和浅拷贝_javascript技巧

理解深拷贝和浅拷贝之前需要弄懂一些基础概念,内存中存储的变量类型分为值类型和引用类型. 1.值类型赋值的存储特点, 将变量内的数据全部拷贝一份, 存储给新的变量. 例如:var num = 123 :var num1=num; 表示变量中存储的数字是 123.然后将数据拷贝一份,就是将 123 拷贝一份. 那么内存中有 2 个 数组;将拷贝数据赋值给 num2,其特点是在内存中有两个数据副本.这可以理解为浅拷贝. 2.引用类型的赋值. var o={name:'张三'}: var obj=o;

浅析iOS中的浅拷贝和深拷贝(copy和mutableCopy)_IOS

ios提供了copy和mutablecopy方法,顾名思义,copy就是复制了一个imutable的对象,而mutablecopy就是复制了一个mutable的对象. copy与retain的区别: copy是创建一个新对象,retain是创建一个指针,引用对象计数加1.Copy属性表示两个对象内容相同,新的对象retain为1 ,与旧有对象的引用计数无关,旧有对象没有变化.copy减少对象对上下文的依赖. retain属性表示两个对象地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的

Python中的赋值、浅拷贝、深拷贝介绍_python

和很多语言一样,Python中也分为简单赋值.浅拷贝.深拷贝这几种"拷贝"方式. 在学习过程中,一开始对浅拷贝理解很模糊.不过经过一系列的实验后,我发现对这三者的概念有了进一步的了解. 一.赋值 赋值算是这三种操作中最常见的了,我们通过一些例子来分析下赋值操作: str例 复制代码 代码如下: >>> a = 'hello' >>> b = 'hello' >>> c = a >>> [id(x) for x in

js对象浅拷贝和深拷贝详解_javascript技巧

本文为大家分享了JavaScript对象的浅拷贝和深拷贝代码,供大家参考,具体内容如下 1.浅拷贝 拷贝就是把父对像的属性,全部拷贝给子对象. 下面这个函数,就是在做拷贝: var Chinese = { nation:'中国' } var Doctor = { career:'医生' } function extendCopy(p) { var c = {}; for (var i in p) { c[i] = p[i]; } c.uber = p; return c; } 使用的时候,这样写

Python高级:细说Python浅拷贝和深拷贝

0.说明          先看看浅拷贝的概念: 浅拷贝:对一个对象进行浅拷贝其实是新创建了一个类型跟原对象一样,其内容还是原来对象元素的引用,换句话说,这个拷贝的对象本身是新的,但是它的内容不是         序列类型对象的浅拷贝是默认类型拷贝,有以下几种实现方式: 完全切片操作:下面操作会有 利用工厂函数:比如list().dict()等 使用copy模块的copy()函数         其实如果是真正理解了Python对象或者说理解了可变对象和不可变对象,再根据上面的理论知识,浅拷贝和

c c++ string-c++ string类型的变量赋值是浅拷贝还是深拷贝?

问题描述 c++ string类型的变量赋值是浅拷贝还是深拷贝? string str1 = "123453"; string str2 = str1; str1和str2的内存地址是相同的吗?str2中某一字符值的改变会影响到str1吗? 解决方案 不同.string 有自己的构造函数来分配空间. 所以不会影响 解决方案二: 浅拷贝还是深拷贝这是对于指针来说的,基本变量是没有这一说的,都是直接分配一个新的内存给它. 所以不会有影响的 解决方案三: string类是stl类,已经封装好