原文:深度解析javascript中的浅复制和深复制

在谈javascript的浅复制和深复制之前,我们有必要在来讨论下js的数据类型。我们都知道有Number,Boolean,String,Null,Undefined,Object五种类型。而Object又包含Function,Array和Object自身。前面的五种类型叫做基本类型,而Object是引用类型。可能有人就要问,为什么要分基本类型和引用类型呢?后面你就会明白的。

我们首先来看看浅复制和深复制的简洁定义:

  • 深复制:直接将数据复制给对应的变量
  • 浅复制:将数据的地址复制给对应的变量

而数据类型和我们要讨论的复制类型又有怎样的联系呢?我们试着摸索一下吧

实验一:

 var a = "dengkunming";
var a1 = a;
alert(a1);//dengkunming
a="abc";
alert(a1);//dengkunming;

这段代码中我们把a赋值给a1,当a的值改变时,a1没有发生变化。

实验二:

 var a = [0,1,2,3];
var a1= a;
alert(a1);//[0,1,2,3]
a[1]="变";
alert(a1);//[0,"变",2,3]

在这段代码中我们同样把a赋值给a1,当a的值改变的时候,a1却发生了变化。

这是咋回事了,同样的操作其结果怎么会有差异了?我们回头看看,聪明的一休认为可能是这两个a有些不同。那些不同了?前面的是字符串,后面的数组。好像就是我们前面提到的基本类型和数据类型吧。那我们把数据类型换一下看看会有什么结果。

实验三:

 var a = 3578;
var a1 = a;
alert(a1);//
a=8735;
alert(a1);//

实验四:

 1 var a = {w1:2,w2:3}
2 var a1= a;
3 alert(a1);//{w1:2,w2:3}
4 a1.w1="邓";
5 alert(a);//{w1:"邓",w2:3}

在这两组实验中,我们把数据类型分别换成了Number型和Object类型。实验三中可以发现a1不随a值的变化而变化,实验四中a会随着a1的变化而变化(这里和实验二略有不同,改变的是a1,当然你改变a的话,a1也会跟着变化)

似乎我们可以得出个一般性的结论了:

    js中基本类型的赋值为深复制,而引用类型的赋值为浅复制。

   现在有必要把深复制和浅复制的定义扩展一下了。

  • 浅复制:就是把数据的地址赋值给对应变量,而没有把具体的数据复制给变量,变量会随数据值的变化而变化。
  • 深复制:就是把数据赋值给对应的变量,从而产生一个与源数据不相干的新数据(数据地址已变化)。

实验五:

 var a = {w1:2,w2:3}
var a1= a;
alert(a1);//{w1:2,w2:3}
var a={x1:7,x2:8}
alert(a1);//{w1:2,w2:3}

按照我们上面的理论来讲,这里是浅复制。a1应该随着a的变化而变化呀,可在这里为什么会事与愿违了?这就是引用类型惹的祸了。对象赋值其实都是引用传值,传递的是一个地址。那么实验五中的第四行其实就是把变量a指向了一个新的地址。而a1还是指向的原来那个地址,原来地址中的值没变,所以a1就不会变。所以请记住:浅复制不会随着存储数据地址的变化而变化,只会随着数据值的变化而变化。

那我们如何实现引用类型的深度复制呢?这就是老话题深度克隆了。就是需要自己写一个非原生的clone函数喽。

 function clone(obj){
var o=[];
if(obj.constructor== Array) {
o=obj.slice(0);
}else{
o={};
for(var i in obj){
o[i] = typeof obj[i] === "object" ? obj[i].clone() : obj[i];}
}
return o; }

    小可不才,文章中定会有所纰漏,望指出。也学一下大牛的语气,此文原创,转载请注明出处。如果你觉得文章还不错,就怒顶并推荐一下下吧!!!!

深度解析javascript中的浅复制和深复制的更多相关文章

  1. 深度解析VC中的消息(转发)

    http://blog.csdn.net/chenlycly/article/details/7586067 这篇转发的文章总结的比较好,但是没有告诉我为什么ON_MESSAGE的返回值必须是LRES ...

  2. 深度解析javaScript常见数据类型检查校验

    前言 在JavaScript中,数据类型分为两大类,一种是基础数据类型,另一种则是复杂数据类型,又叫引用数据类型 基础数据类型:数字Number 字符串String 布尔Boolean Null Un ...

  3. 深入解析Javascript中this关键字的使用

    深入解析Javascript中面向对象编程中的this关键字 在Javascript中this关键字代表函数运行时,自动生成的一个内部对象,只能在函数内部使用.比如: function TestFun ...

  4. JAVA中浅复制与深复制 - coolmist - ITeye技术网站

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

  5. Java中引用的浅复制和深复制

    Java中除了基本类型int,char,double等的赋值是按照值传递之外,其余的类型和对象都是按照引用进行传递的. 下面来看一个关于引用的例子. package referenceCopy;// ...

  6. js中的浅复制和深复制

    浅复制:浅复制是复制引用,复制后的引用都是指向同一个对象的实例,彼此之间的操作会互相影响 深复制:深复制不是简单的复制引用,而是在堆中重新分配内存,并且把源对象实例的所有属性都进行新建复制,以保证深复 ...

  7. 全面解析JavaScript中“&&”和“||”操作符(总结篇)

    1.||(逻辑或), 从字面上来说,只有前后都是false的时候才返回false,否则返回true. ? 1 2 3 4 alert(true||false); // true alert(false ...

  8. JAVA中浅复制与深复制

    1.浅复制与深复制概念⑴浅复制(浅克隆)被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象.换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象. ⑵深复 ...

  9. Java中的“浅复制”与“深复制”

    复制 将一个对象的引用复制给另一个对象,一共有三种方式.第一种方式是直接赋值,第二种方式是浅复制,第三种方式是深复制. 1.直接赋值 在Java中,A a1 = a2,这实际上复制的是引用,也就是说 ...

随机推荐

  1. [LeetCode257]Binary Tree Paths

    题目: Given a binary tree, return all root-to-leaf paths. For example, given the following binary tree ...

  2. Java SE学习之数组——匿名数组和不规则数组

    本文是学习网络上的文章时的总结以及自己的一点实践.感谢大家无私的分享. 近期偶然遇到了数组的问题,学习了匿名数组和不规则数组. 匿名数组适用于仅仅使用一次的情况:不规则数组适用是每行数据总数不确定的情 ...

  3. Robotium调用getActivity()导致程序挂起的方法

    1. 问题背景的叙述性说明 需要直接用在工作中没有项目的源代码robotium测试目标android平台launcher,该平台的基础上,当前日期的版本号android 4.4.2.之前我用来验证的可 ...

  4. 《Pro Android Graphics》读第三季度票据

    Android Frame Animation: XML, Concepts and Optimization Frame Animation Concepts: Cels, Framerate, a ...

  5. UVALive 6469 Deranged Exams (排列:力绝对是无辜的高中知识啊)

    标题手段 : 给你个n([1,17])表达n无论从数据结构.然后n个对这些术语的定义,让你对这些术语和定义对号入座(相当于进行连线,A术语连A术语的定义).然后一个 k([0,n]).问你至少前k个术 ...

  6. JAVA学习课第五 — IO流程(九)文件分割器合成器

    文件分割器 private static final int SIZE = 1024 *1024; public static void splitFile(File file) throws IOE ...

  7. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  8. UWP开发的一些思考

    UWP开发的一些思考 领域驱动和MVVM应用于UWP开发的一些思考 0x00 起因 有段时间没写博客了,其实最近本来是根据梳理的MSDN上的资料(UWP开发目录整理)有条不紊的进行UWP学习的.学习中 ...

  9. 三种字符编码:ASCII、Unicode和UTF-8

    原文:三种字符编码:ASCII.Unicode和UTF-8 什么是字符编码? 计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.最早的计算机在设计时采用8个比特(bit)作为一个字 ...

  10. BZOJ 1823 JSOI 2010 盛宴 2-SAT

    标题效果:有着n材料的种类,m陪审团. 每种材料具有两种不同的方法.每个法官都有两个标准.做出来的每一个法官的菜必须至少满足一个需求. 问:是否有这样一个程序. 思考:2-SAT经典的内置图形问题.因 ...