【转】精简深拷贝ArrayList实例
原文网址:http://gghhgame51333.blog.51cto.com/138362/289383
|
作者fbysss
msn:jameslastchina@hotmail.com blog:blog.csdn.net/fbysss 声明:本文由fbysss原创,转载请注明出处 关键字:深拷贝,序列化 前言: import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.util.ArrayList; import java.util.List; /** *//**
* <p>标题: </p> * <p>功能描述: <br> * * </p> * <p>版权: Copyright (c) 2007</p> * <p>公司: </p> * @author fbysss * @version 1.0 * * </p> * <p>修改记录:</p> * 创建时间:2007-7-12 13:34:56 * 类说明 */ public class DeepCopy ...{ //深拷贝1:递归方法
public void copy(List src,List dest)...{ for (int i = 0 ;i < src.size() ; i++) ...{ Object obj = src.get(i); if (obj instanceof List)...{ dest.add(new ArrayList()); copy((List)obj,(List)((List)dest).get(i)); }else...{ dest.add(obj); } } } //深拷贝2:序列化|反序列化方法
public List copyBySerialize(List src) throws IOException, ClassNotFoundException...{ ByteArrayOutputStream byteOut = new ByteArrayOutputStream(); ObjectOutputStream out = new ObjectOutputStream(byteOut); out.writeObject(src); ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray()); ObjectInputStream in =new ObjectInputStream(byteIn); List dest = (List)in.readObject(); return dest; } //浅拷贝 public void copyByAdd(List src,List dest)...{ //for (Object obj : src) {//jdk 1.5 以上版本 for (int i = 0 ; i< src.size() ;i++) ...{//jdk 1.4 Object obj = src.get(i); dest.add(obj); } } //添加引用 public void evalByAdd(List src,List dest)...{ dest.add(src); } //直接引用 public List evalByRef(List src)...{ return src; } /** *//** * @param args */ public static void main(String[] args) ...{ List srcList = new ArrayList(); List srcSubList1 = new ArrayList(); srcSubList1.add("subItem1-1"); srcSubList1.add("subItem1-2"); srcSubList1.add("subItem1-3"); List srcSubList2 = new ArrayList(); srcSubList2.add("subItem2-1"); srcSubList2.add("subItem2-2"); srcSubList2.add("subItem2-3"); srcList.add(srcSubList1); srcList.add(srcSubList2); List destList = new ArrayList(); DeepCopy dc = new DeepCopy(); /** *//***********test#1*******************/ //dc.copy(srcList,destList); /** *//***********test#2*******************/ /**//* try { destList = dc.copyBySerialize(srcList); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } */ /** *//***********test#3*******************/ dc.copyByAdd(srcList,destList); ((List)srcList.get(0)).remove(0); /** *//***********test#4*******************/ /**//* destList = dc.evalByRef(srcList); */ srcList.remove(1); dc.printList(destList); } private void printList(List destList) ...{ //for (Object obj : destList) {//jdk 1.5 以上版本 for (int i = 0 ; i< destList.size() ;i++) ...{//jdk 1.4 Object obj = destList.get(i); if (obj instanceof List)...{ List listObj = (List)obj; printList((List)listObj); }else...{ System.out.println(obj.toString()); } } } }
运行结果: test#1和test#2由于是深拷贝,输出的都是完整的元素; test#3为浅拷贝, 不受 srcList.remove(1);的影响,但是一旦加了((List)srcList.get(0)).remove(0);就会发现少了第一个元素; test#4完全是引用src,src的任何改动都会影响dest的输出。 |
【转】精简深拷贝ArrayList实例的更多相关文章
- 对Python中列表和数组的赋值,浅拷贝和深拷贝的实例讲解
引用:https://www.jb51.net/article/142775.htm 列表赋值: 1 2 3 4 5 6 7 >>> a = [1, 2, 3] >>&g ...
- Java集合类库list(1)ArrayList实例
public class ArrayListTest { public static void main(String[] args) { //创建空的ArrayList列表 ArrayList al ...
- ensureCapacity增加此 ArrayList 实例的容量,以确保它至少能够容纳最小容量参数所指定的元素数。
扩容原则: 若参数值大于底层数组长度的1.5倍,则数组的长度就扩容为这个参数值:若小于底层数组长度的1.5倍,则数组长度就扩容为底层数组长度的1.5倍. ensureCapacity提高效率 fina ...
- 无法反序列化的java.util.ArrayList实例出来VALUE_STRING的(Can not deserialize instance of java.util.ArrayList out of VALUE_STRING)
解决方法: 设置DeserializationConfig.Feature.ACCEPT_SINGLE_VALUE_AS_ARRAY.问题解决.
- Java中如何克隆集合——ArrayList和HashSet深拷贝
编程人员经常误用各个集合类提供的拷贝构造函数作为克隆List,Set,ArrayList,HashSet或者其他集合实现的方法.需要记住的是,Java集合的拷贝构造函数只提供浅拷贝而不是深拷贝,这意味 ...
- 内功心法 -- java.util.ArrayList<E> (1)
写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...
- java容器详解(以Array Arrays ArrayList为例)
//先记录一个想法……java实在是太臃肿了,纯面向对象也有不少弊端…… //能不能把java精简一下啊! 先上结论: Array:认真看api索引的话,Array有两个.一个是sql中的接口,一个是 ...
- C#语言基础——集合(ArrayList集合)
集合及特殊集合 集合的基本信息: System.Collections 命名空间包含接口和类,这些接口和类定义各种对象(如列表.队列.位数组.哈希表和字典)的集合.System.Collections ...
- ArrayList源码阅读笔记(基于JDk1.8)
关键常量: private static final int DEFAULT_CAPACITY = 10; 当没有其他参数影响数组大小时的默认数组大小 private static final Obj ...
随机推荐
- POJ2104-- K-th Number(主席树静态区间第k大)
[转载]一篇还算可以的文章,关于可持久化线段树http://finaltheory.info/?p=249 无修改的区间第K大 我们先考虑简化的问题:我们要询问整个区间内的第K大.这样我们对值域建线段 ...
- Java虚拟机内存优化实践
前面一篇文章介绍了Java虚拟机的体系结构和内存模型,既然提到内存,就不得不说到内存泄露.众所周知,Java是从C++的基础上发展而来的,而C++程序的很大的一个问题就是内存泄露难以解决,尽管Java ...
- 你需要知道的12个Git高级命令
众所周知,Git目前已经是分布式版本控制领域的翘楚,围绕着Git形成了完整的生态圈.学习Git,首先当然是学习Git的基本工作流.相比于SVN等传统版本控制系统来说,Git是专为分布式版本控制而生的强 ...
- Hadoop2.4.1 使用MapReduce简单的数据清洗
package com.bank.service; import java.io.IOException;import java.text.ParseException;import java.tex ...
- CSS常用操作-导航栏
1.垂直导航栏 index.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...
- 【转】MVC5中的区域(Areas)
MVC本身提倡的就是关注点分离.但是当项目本身的业务逻辑足够复杂,如果所有的业务逻辑都写个Controller文件夹下面的时候,你会看到非常庞大的各种命名的Controller,这个时候区域的作用就非 ...
- yii 笔记
Yii1.1: $_GET 可以表示为 Yii::app()->request->getQuery() $_POST 可以表示为 Yii::app()->request->po ...
- C++ 推断进程是否存在
[cpp] view plaincopyprint? #include <windows.h> #include "psapi.h" #include"std ...
- 全文搜索-介绍-elasticsearch-definitive-guide翻译
全文搜索 我们通过前文的简单样例,已经了解了结构化数据的条件搜索:如今.让我们来了解全文搜索-- 如何通过匹配全部域的文本找到最相关的文章. 关于全文搜索有两个最重要的方面: 相似度计算 通过TF/I ...
- Java可见性机制的原理
基本概念 可见性 当一个线程修改了共享变量时,另一个线程可以读取到这个修改后的值. 内存屏障(Memory Barriers) 处理器的一组指令,用于实现对内存操作的顺序限制. 缓冲行 CPU告诉缓存 ...