linkedlist-java Arraylist和Linkedlist中set返回值为什么是old值

问题描述

java Arraylist和Linkedlist中set返回值为什么是old值

小弟自学了Arraylist和Linkedlist,但是有一点令我疑惑不解,求大婶帮助:
public E set(int index, E element) {
checkElementIndex(index);
Node x = node(index);
E oldVal = x.item;
x.item = element;
return oldVal; //我想问为什么这儿返回返回修改前的值(Arraylistlist也一样)
}

解决方案

因为x是一个引用类型,对于引用类型,你必须new一个对象,并且逐字段拷贝属性值过来才能保留住原来的值。
否则你复制的只是一个引用,其实两者是一个对象,你通过新引用改变了值,老引用还是指向它,自然跟着变了。

解决方案二:

http://solodu.iteye.com/blog/472013

解决方案三:

对象传输的是引用,而不是对象本身。 好好理解下这个代码。

时间: 2024-09-20 17:44:25

linkedlist-java Arraylist和Linkedlist中set返回值为什么是old值的相关文章

[Java] ArrayList、LinkedList、Vector的区别

版权声明:请尊重个人劳动成果,转载注明出处,谢谢! 首先我们来看一下继承关系: 我们可以看出ArrayList.LinkedList.Vector都实现了List的接口.  接下来分别看一下三个数据结构的说明. public class ArrayList extends AbstractList  implements List, RandomAccess, Cloneable, Serializable List 接口的大小可变数组的实现.实现了所有可选列表操作,并允许包括 null 在内的

java 算法-在JAVA-WEB中取得控件的名字和值

问题描述 在JAVA-WEB中取得控件的名字和值 while(enumeration.hasMoreElements()){ String nameString = enumeration.nextElement(); String[] valueStrings = request.getParameterValues(nameString); //由于名字可能会重复 for (String string : valueStrings) { System.out.println(nameStri

Java中ArrayList和LinkedList的遍历与性能分析_java

前言 通过本文你可以了解List的五种遍历方式及各自性能和foreach及Iterator的实现,加深对ArrayList和LinkedList实现的了解.下面来一起看看吧. 一.List的五种遍历方式 1.for each循环 List<Integer> list = new ArrayList<Integer>(); for (Integer j : list) { // use j } 2.显示调用集合迭代器 List<Integer> list = new Ar

分析Java中ArrayList与LinkedList列表结构的源码_java

一.ArrayList源码分析(JDK7) ArrayList内部维护了一个动态的Object数组,ArrayList的动态增删就是对这个对组的动态的增加和删除. 1.ArrayList构造以及初始化 ArrayList实例变量 //ArrayList默认容量 private static final int DEFAULT_CAPACITY = 10; //默认空的Object数组, 用于定义空的ArrayList private static final Object[] EMPTY_ELE

Java中ArrayList和LinkedList区别

一般大家都知道ArrayList和LinkedList的大致区别: 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针. 3.对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据. ArrayList和LinkedList是两个集合类,用于存储一系列的对象引用(references).例如

java中LinkedList和ArrayList性能比对

   代码如下 复制代码 package com.letv.cloud.cdn.jtest;    import java.io.IOException;  import java.util.ArrayList;  import java.util.LinkedList;  import java.util.List;  import java.util.concurrent.TimeUnit;    import org.slf4j.LoggerFactory;    import com.g

JAVA LinkedList和ArrayList的使用及性能分析_java

第1部分 List概括List的框架图List 是一个接口,它继承于Collection的接口.它代表着有序的队列.AbstractList 是一个抽象类,它继承于AbstractCollection.AbstractList实现List接口中除size().get(int location)之外的函数.AbstractSequentialList 是一个抽象类,它继承于AbstractList.AbstractSequentialList 实现了"链表中,根据index索引值操作链表的全部函数

Java基础-16总结List的子类,ArrayList,Vector,LinkedList,泛型,增强for循环,静态导入,可变参数

你需要的是什么,直接评论留言. 获取更多资源加微信公众号"Java帮帮" (是公众号,不是微信好友哦) 还有"Java帮帮"今日头条号,技术文章与新闻,每日更新,欢迎阅读 学习交流请加Java帮帮交流QQ群553841695 分享是一种美德,分享更快乐! 1:List的子类(掌握) (1)List的子类特点 ArrayList: 底层数据结构是数组,查询快,增删慢 线程不安全,效率高 Vector: 底层数据结构是数组,查询快,增删慢 线程安全,效率低 Linked

java集合框架05——ArrayList和LinkedList的区别

本文为博主原创文章,转载请注明出处:http://blog.csdn.net/eson_15/article/details/51145788 前面已经学习完了List部分的源码,主要是ArrayList和LinkedList两部分内容,这一节主要总结下List部分的内容. List概括         先来回顾一下List在Collection中的的框架图:     从图中我们可以看出:         1. List是一个接口,它继承与Collection接口,代表有序的队列.