首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

由java中深度复制一伸出Collections.copy的应用

2012-12-28 
由java中深度复制一伸出Collections.copy的使用今天在学习集合中 有关对象的深度拷贝和浅拷贝 的时候,像拷

由java中深度复制一伸出Collections.copy的使用
今天在学习集合中 有关对象的深度拷贝和浅拷贝 的时候,像拷贝一个ArrayList对象到另一个ArrayList对象中,正好发现Collections有一个copy方法。可是不好用啊总是报错。查看api才知道,它的capacity(容纳能力大小)可以指定(最好指定)。而初始化时size的大小永远默认为0,只有在进行add和remove等相关操作 时,size的大小才变化。然而进行copy()时候,首先做的是将desc的size和src的size大小进行比较,只有当desc的 size 大于或者等于src的size时才进行拷贝,否则抛出IndexOutOfBoundsException异常;

import java.util.ArrayList;import java.util.Arrays;import java.util.Collections;import java.util.List;public class test1 { /**  * Collections.copy()使用的小技巧  * @param args  */ public static void main(String[] args) {  // TODO Auto-generated method stub  List<String> src = new ArrayList<String>();  src.add("111");  src.add("222");  src.add("333");  src.add("444");  List<String> dic = new ArrayList<String>(Arrays.asList(new String[src    .size()]));  Collections.copy(dic, src);  for (Object s : dic) {   System.out.println(s);  } }}


第二种办法:
dest1  =   new  ArrayList();
Collections.addAll(dest1,  new  Object[src1.size()]);
Collections.copy(dest1, src1);
public static void main(String[] args) {  // TODO Auto-generated method stub  List<String> src = new ArrayList<String>();  src.add("111");  src.add("222");  src.add("333");  src.add("444");  List<String> dest1  =   new  ArrayList<String>();  Collections.addAll(dest1,  new  String[src.size()]);  Collections.copy(dest1, src);  for (Object s : dest1) {   System.out.println(s);  }



本文引用: http://sdxiaozhuanhao.blog.163.com/blog/static/181632384201263054442101/






偶然看到了Collections的copy(List desc,List src)方法.当时就想这个方法和初始化一个List desc = new  ArrayList(List c)【参数必须实现Collection接口】的区别。

两者的差别很大,后者是一个浅拷贝,只是对源list的元素进行拷贝,拷贝的只是引用。拷贝后两个list的元素(引用)不同,但是引用所指向的对象是一 样的。即是两个list的每个元素指向的还是通一内存。然而前者是深拷贝,不光拷贝的是src的元素(引用),src内每个元素的所指向的对象都进行一次 拷贝。即是两个list的每个元素所指向的不是同一内存。


如果你使用下面方法copy
/** **************************** */
List des1 = new  ArrayList( 3 );
Collections.copy(des1,src1);
/** **************************** */
将会出错,抛出数组越界异常。
当时我怎么想都想不明白为什么,明明已经设置了长度为3,为什么还会出错!
后来打印出des1.size()才知道des1的长度为0;3表示的是这个List的容纳能力为3,并不是说des1中就有了3个元素。查看api才知 道,它的capacity(容纳能力大小)可以指定(最好指定)。而初始化时size的大小永远默认为0,只有在进行add和remove等相关操作 时,size的大小才变化。然而进行copy()时候,首先做的是将desc1的size和src1的size大小进行比较,只有当desc1的 size 大于或者等于src1的size时才进行拷贝,否则抛出IndexOutOfBoundsException异常。

所以可以通过下面的方法指定目标desc的大小
/** **************************** */
List des1 = new  ArrayList(Array.asList( new  object[src1.size])); // 注意:new ArrayList(Collection col)参数必须要实现Collection 接口。
Collections.copy(des1,src1);
/** **************************** */
执行第一句后size的大小是3,其实它是对一个空数组的浅拷贝。
使用这位仁兄的方法,我这边一直报错说找不到此构造函数,估计是因为我使用了jdk6的原因,后来使用了替代方法,用apache的CollectionUtils:

dest1  =   new  ArrayList();
CollectionUtils.addAll(dest1,  new  Object[src1.size()]);
Collections.copy(dest1, src1);
本文引用: http://blog.csdn.net/liulin_good/article/details/6109090

热点排行