- 浏览: 535397 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (119)
- java总结 (43)
- Spring (2)
- 反编译工具 (1)
- hibernate (1)
- Tomcat (1)
- WebLogic (2)
- 随笔 (4)
- Word问题小记 (2)
- web前端 (26)
- Oracle (10)
- DOS (1)
- 面试笔试 (3)
- Servlet (1)
- jQuery (1)
- Linux/Unix (2)
- JSTL (1)
- struts2 (2)
- JSON (2)
- Velocity (0)
- 生活 (3)
- MyEclipse使用小结 (1)
- 操作系统 (2)
- jqgrid (1)
- ajax-dwr (1)
- javascript (18)
- dreamweaver (2)
- html (10)
- css (5)
- 正则表达式 (1)
- IO (3)
最新评论
-
a363722188:
<div class="quote_title ...
由java中深度复制一伸出Collections.copy的使用 -
幽默者:
老兄,Collections.copy(dest1, src1 ...
由java中深度复制一伸出Collections.copy的使用 -
raymao:
java 中 split 是正则表达式
java 和 javascript split 的区别! -
413899327:
面试前端javascript
阿里电话面试 -
yzsunlight:
你面试前台UI?
阿里电话面试
今天在学习集合中 有关对象的深度拷贝和浅拷贝 的时候,像拷贝一个ArrayList对象到另一个ArrayList对象中,正好发现Collections有一个copy方法。可是不好用啊总是报错。查看api才知道,它的capacity(容纳能力大小)可以指定(最好指定)。而初始化时size的大小永远默认为0,只有在进行add和remove等相关操作 时,size的大小才变化。然而进行copy()时候,首先做的是将desc的size和src的size大小进行比较,只有当desc的 size 大于或者等于src的size时才进行拷贝,否则抛出IndexOutOfBoundsException异常;
第二种办法:
dest1 = new ArrayList();
Collections.addAll(dest1, new Object[src1.size()]);
Collections.copy(dest1, src1);
本文引用: 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
楼主的两种方法都是浅复制
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
评论
2 楼
a363722188
2016-03-10
幽默者 写道
老兄,Collections.copy(dest1, src1); 这种方式最好验证一下。其实也是浅复制
楼主的两种方法都是浅复制
1 楼
幽默者
2015-08-24
老兄,Collections.copy(dest1, src1); 这种方式最好验证一下。其实也是浅复制
发表评论
-
文件操作待整理
2013-10-16 16:14 1716package test; import java. ... -
Java追加文件内容的三种方法
2013-10-16 15:22 8988/** * 描述:追加内容到文件末尾 ... -
jajva IO常用写法
2013-10-16 13:58 1200// 指定编码读取文件路径创建缓冲输入流 Buffered ... -
Java 使用正则表达式从文件中解析出所有email地址
2013-10-16 13:36 14362import java.io.File; import ... -
java 和 javascript split 的区别!
2013-09-18 10:52 1634java 和 javascript split 的区别! ... -
javascrip如何创建命名空间
2013-09-18 10:49 1197看代码,废话不多说! <!DOCTYPE ht ... -
请教个问题,java在后台跑的线程如何控制他的超时时间,超过一段时间自动停止?
2013-03-22 09:43 1112请教个问题,java在后台跑的线程如何控制他的超时时间,超过一 ... -
java 用jdbc方式以 sys账号连接oracle数据的问题
2013-02-26 11:53 9664jdbc.properties driver=oracl ... -
java 对象深拷贝通用方法
2012-12-17 14:02 5458⑴浅复制(浅克隆) 被复制对象的所有变量都含有与原来的对象相同 ... -
java中ArrayList深拷贝有关问题
2012-12-16 23:50 6121基本思路就是将要深拷贝的对象实现Serializable接口。 ... -
JAVA 时间 和 js里面时间的区别
2012-04-13 11:31 2417JAVA 里面处理时间时,只要按照format格式去解析时间, ... -
java 多级目录创建文件
2011-12-21 10:43 5677方式一: File file = new File(&q ... -
java获取文件名的三种方法
2011-10-09 15:47 77508import java.io.File; imp ... -
三种for循环样式
2011-09-27 20:42 1442三种for循环样式 1、for(int i = 0;i & ... -
随机生成颜色
2011-08-25 09:24 5567import java.util.Random; ... -
在Eclipse下运行是不能使用Console类
2011-07-07 23:43 3148在Eclipse下运行是不能使用Console类。 Con ... -
3种Java从文件路径中获取文件名的方法
2011-05-11 09:53 30511package test; import java.i ... -
数组转集合Collections:Arrays.asList(values)
2011-05-05 17:23 1867将一个数组转换为list集合时,使用List <数组类型 ... -
迭代Map
2011-04-13 09:13 1122for ( Iterator iterator = aM ... -
详解Java重载(Overload)
2010-12-11 22:20 1849重载(Overload) 覆 ...
相关推荐
总结起来,`Collections.sort()`是Java中对List进行排序的标准工具,它支持自然排序和自定义排序。了解其工作原理和优化技巧,可以帮助我们在编程实践中更高效地处理数据。通过阅读和理解`Collections.sort()`的源码...
commons-collections-20040616.jar, ...commons-collections.jar, commons-collections3-3.2.1.jar, commons-collections4-4.1-javadoc.jar, commons-collections4-4.1-src.zip, commons-collections4-4.1.jar
《iesi.collections.dll:C# .Net集合全版本解析》 iesi.collections.dll是一个与C#编程...在实际使用中,开发者应当结合项目特性,充分利用iesi.collections.dll提供的功能,以实现高效、稳定和易于维护的软件系统。
例如,Collections.sort()方法可以对List进行排序,而Collections.synchronizedXXX()方法则可以帮助我们创建线程安全的集合。 在实际开发中,选择合适的集合类型和方法至关重要。例如,当我们需要保持元素插入顺序...
标题中的"Collections.synchronizedList"是指Java集合框架中的一个静态工厂方法,用于将任何List转换为线程安全的List。这个方法是Java中实现多线程环境下的集合操作的重要工具,确保在并发访问时数据的一致性和完整...
Java中的Collections.sort排序是Java.util.Collections类中的一个静态方法,用于对列表进行排序。下面将详细介绍Collections.sort排序的使用和实现机制。 Collections.sort()方法的使用: Collections.sort()方法...
代码中两次使用了`Collections.frequency(list, "abc")`和`Collections.frequency(list, "123")`分别计算"abc"和"123"在列表中出现的次数。 通过这些例子,我们可以看到`Collections`类如何方便地对Java集合进行...
在这个特定的场景中,异常堆栈跟踪显示了 `Caused by: java.lang.ClassNotFoundException: org.apache.commons.collections.Transformer`,这表明系统无法找到 `org.apache.commons.collections.Transformer` 类。...
在Java编程语言中,`Collections.sort()` 方法是一个非常重要的工具,用于对List接口实现的集合进行排序。这个方法使得开发者能够方便地按照指定的顺序排列集合中的元素。本篇文章将详细探讨如何使用 `Collections....
在Kotlin编程语言中,`kotlinx.collections.immutable`是一个重要的库,它提供了不可变集合的实现。不可变集合是一旦创建后就不能修改的集合,这种数据结构在多线程环境、函数式编程和构建安全的数据模型时非常有用...
在给定的压缩包"Java-Development-Kits-Collections.zip_gwt-console-rpc.jar_mchang"中,我们可以看到几个关键元素:Java开发工具集合、GWT(Google Web Toolkit)的RPC库以及MChange相关的组件。 首先,Java ...
Apache Commons Collections库是Java开发中的一个强大工具,它提供了一系列高效、实用的数据结构和算法。在处理Excel2007(.xlsx)文件时,可能会遇到`org.apache.commons.collections`找不到的错误,这个问题通常是...
**Java泛型** 是自Java 5引入的一种机制,它允许在类、接口和方法声明中使用类型参数,以实现更强大的类型检查和更少的类型转换。泛型的主要优点包括: 1. **类型安全**:编译时可以检查错误,避免了运行时...