写在前面的话:读书破万卷,编码如有神
--------------------------------------------------------------------
下文主要对java.util.ArrayList<E>的4个批量操作进行介绍,主要内容包括:

1、ArrayList的批量操作

参考内容:

1、JDK源码(1.7)

-------------------------------------------------------------------- 

1. ArrayList常用的4个批量操作

批量操作:

(1) boolean addAll(Collection<? extends E> c)

功能: 将子列表c中的元素全部添加到列表中去

示例代码:

 public class ArrayListTest {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(0,44);
list.add(1,33);
list.add(2,22);
list.add(1,66);
list.add(4,99);
list.add(2,66);
list.add(1,44);
System.out.println("list :" + list);
//测试ArrayList的'boolean addAll(Collection<? extends E> c)'方法的使用
ArrayList<Integer> list2 = new ArrayList<Integer>();
list2.add(51);
list2.add(52);
list2.add(53);
list2.add(54);
list.addAll(list2);
System.out.println("list2 : " + list2);
System.out.println("list :" + list);
}
} 运行结果:
list :[44, 44, 66, 66, 33, 22, 99]
list2 : [51, 52, 53, 54]
list :[44, 44, 66, 66, 33, 22, 99, 51, 52, 53, 54]

源代码如下:

 public boolean addAll(Collection<? extends E> c) {
//将子列表c转换为数组
Object[] a = c.toArray();
//子列表中元素的个数
int numNew = a.length;
//进行容量检查,如果需要扩容则进行扩容处理
ensureCapacityInternal(size + numNew); // Increments modCount
//将子列表c添加到列表的size开始的位置处
System.arraycopy(a, 0, elementData, size, numNew);
size += numNew;
return numNew != 0;
}

(2) boolean addAll(int index,Collection<? extends E> c)

功能: 将子列表c添加到列表的index索引位置

示例代码:

 public class ArrayListTest {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(0,44);
list.add(1,33);
list.add(2,22);
list.add(1,66);
list.add(4,99);
list.add(2,66);
list.add(1,44);
System.out.println("list :" + list);
//测试ArrayList的'boolean addAll(int index,Collection<? extends E> c)'方法的使用
ArrayList<Integer> list2 = new ArrayList<Integer>();
list2.add(51);
list2.add(52);
list2.add(53);
list2.add(54);
System.out.println("list2 : " + list2);
list.addAll(3,list2);
System.out.println("list :" + list);
list.addAll(30,list2);//将会抛出IndexOutOfBoundsException异常
System.out.println("list :" + list);
}
} 运行结果:
list :[44, 44, 66, 66, 33, 22, 99]
list2 : [51, 52, 53, 54]
list :[44, 44, 66, 51, 52, 53, 54, 66, 33, 22, 99]
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 30, Size: 11
at java.util.ArrayList.rangeCheckForAdd(Unknown Source)
at java.util.ArrayList.addAll(Unknown Source)
at ArrayListTest.main(ArrayListTest.java:24)

源代码如下:

     public boolean addAll(int index, Collection<? extends E> c) {
//检查index是否合法,如果不合法,则抛出异常
rangeCheckForAdd(index);
//将子列表转换为数组
Object[] a = c.toArray();
//记录子列表中元素的个数
int numNew = a.length;
//进行扩容检查,如果需要扩容则进行扩容处理
ensureCapacityInternal(size + numNew); // Increments modCount
//计算出列表中元素需要移位的个数
int numMoved = size - index;
//进移位操作
if (numMoved > 0)
System.arraycopy(elementData, index, elementData, index + numNew,numMoved);
//将子列表c放置到集合index位置开始处
System.arraycopy(a, 0, elementData, index, numNew);
//列表中元素个数加numNew
size += numNew;
return numNew != 0;
}

(3) void clear()

功能: 将列表中的元素清空

示例代码:

 public class ArrayListTest {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(0,44);
list.add(1,33);
list.add(2,22);
list.add(1,66);
list.add(4,99);
list.add(2,66);
list.add(1,44);
System.out.println("list :" + list);
//测试ArrayList的'void clear()'方法的使用
list.clear();
System.out.println("list :" + list);
}
} 运行结果:
list :[44, 44, 66, 66, 33, 22, 99]
list :[]

源代码如下:

     public void clear() {
//fast-fail机制标识
modCount++;
//利用循环将列表中全部元素置为null
// Let gc do its work
for (int i = 0; i < size; i++)
elementData[i] = null;
//将属性size设置为0
size = 0;
}

(4) public boolean removeAll(Collection<?> c)、public boolean retainAll(Collection<?> c)

功能:

  removeAll(Collection<?> c)移除列表中那些也包含在指定子列表c中的所有元素

  retainAll(Collection<?> c)移除列表中那些不包含在指定子列表c中的所有元素

示例代码: removeAll(Collection<?> c)

 public class ArrayListTest {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(22);
list.add(33);
list.add(44);
list.add(11);
list.add(15);
list.add(12);
list.add(7);
list.add(3);
System.out.println("list :" + list);
//测试ArrayList的'public boolean removeAll(Collection<?> c)'方法的使用
ArrayList<Integer> list2 = new ArrayList<Integer>();
list2.add(44);
list2.add(15);
list2.add(13);
System.out.println("list2 :" + list2);
list.removeAll(list2);
System.out.println("list.removeAll(list2) :" + list);
}
} 运行结果:
list :[22, 33, 44, 11, 15, 12, 7, 3]
list2 :[44, 15, 13]
list.removeAll(list2) :[22, 33, 11, 12, 7, 3]

示例代码: retainAll(Collection<?> c) ,从运行结果可以看出运行这个方法的结果是:原列表和子列表c取交集后的结果

 public class ArrayListTest {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(22);
list.add(33);
list.add(44);
list.add(11);
list.add(15);
list.add(12);
list.add(7);
list.add(3);
System.out.println("list :" + list);
//测试ArrayList的'public boolean removeAll(Collection<?> c)'方法的使用
ArrayList<Integer> list2 = new ArrayList<Integer>();
list2.add(44);
list2.add(15);
list2.add(13);
System.out.println("list2 :" + list2);
list.retainAll(list2);
System.out.println("list.retainAll(list2) :" + list);
}
} 运行结果:
list :[22, 33, 44, 11, 15, 12, 7, 3]
list2 :[44, 15, 13]
list.retainAll(list2) :[44, 15]

源代码如下:(感觉JDK的源代码就是写的好呀,batchRemove()方法写的很棒)

 public boolean removeAll(Collection<?> c) {
return batchRemove(c, false);
} public boolean retainAll(Collection<?> c) {
return batchRemove(c, true);
} private boolean batchRemove(Collection<?> c, boolean complement) {
final Object[] elementData = this.elementData;
int r = 0, w = 0;
boolean modified = false;
try {
//利用循环查询列表元素是否在子列表c
for (; r < size; r++)
if (c.contains(elementData[r]) == complement)
elementData[w++] = elementData[r];
} finally {
// Preserve behavioral compatibility with AbstractCollection,
// even if c.contains() throws.
if (r != size) {
System.arraycopy(elementData, r,
elementData, w,
size - r);
w += size - r;
}
if (w != size) {
for (int i = w; i < size; i++)
elementData[i] = null;
modCount += size - w;
size = w;
modified = true;
}
}
return modified;
}

---------------------------------------------------------------------------------------

java.util.ArrayList系列文章

java.util.ArrayList<E>(1)  java.util.ArrayList<E>(2)  java.util.ArrayList<E>(3)

java.util.ArrayList<E>(4)  java.util.ArrayList<E>(5)  java.util.ArrayList<E>(6)

相关知识                                                                                              

java.util.Collection<E>   java.util.AbstractCollection<E>   java.util.List<E>

java.util.AbstractList<E>   java.util.Iterator<E>   java.util.ListIterator<E>

Java中的标记接口   迭代器模式   Java中的深拷贝和浅拷贝  java.util.Arrays

内功心法 -- java.util.ArrayList<E> (4)的更多相关文章

  1. 内功心法 -- java.util.ArrayList<E> (1)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...

  2. 内功心法 -- java.util.ArrayList<E> (2)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...

  3. 内功心法 -- java.util.ArrayList<E> (3)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...

  4. 内功心法 -- java.util.ArrayList<E> (5)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...

  5. 内功心法 -- java.util.ArrayList<E> (6)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------下文主要对java.util ...

  6. 解决springmvc报No converter found for return value of type: class java.util.ArrayList问题

    一.背景 最近闲来无事,想自己搭建一套Spring+SpringMVC+Mybatis+Mysql的环境(搭建步骤会在以后博客中给出),结果运行程序时,适用@ResponseBody注解进行返回Lis ...

  7. Java.util.ArrayList详解

    java.util.ArrayList就是传说中的动态数组. 继承了关系,有此可看出ArrayList与list的collection的关系 public class ArrayList<E&g ...

  8. java@ 利用ArrayList实现dijkstra算法以及topological 排序算法(java.util.ArrayList)

    package dataStructure; import java.util.ArrayList; import java.util.LinkedList; import java.util.Que ...

  9. java.util.ArrayList、java.util.vector和java.util.LinkedList (JDK 1.8.0_111)

    一.java.util.ArrayList 1.1 ArrayList 继承结构 ArrayList实现了RandomAccess,可以随机访问(其实就是通过数组下标访问):实现了Cloneable, ...

随机推荐

  1. 前端教程&开发模块化/规范化/工程化/优化&工具/调试&值得关注的博客/Git&面试-资源汇总

    内容精简 资源这么多,多看看多学习再总结肯定是好的.多读读就算看重了不算浪费时间,毕竟一千个读者就有一千个林黛玉,还有温故而知新,说不定多读一些内容,就发现惊喜了呢.不过,在此也精简一些内容,就1~2 ...

  2. 从url中提取参数名和参数值(转)

    在已知参数名的情况下,获取参数值,使用正则表达式能很容易做到.js的实现方法如下: function getValue(url, name) { var reg = new RegExp('(\\?| ...

  3. hibernate---一级缓存, 二级缓存, 查询缓存

    缓存: 内存开辟一块空间,把本来存在硬盘的东西放在内存里, 以后从内存读取. 一级缓存: session级别的缓存, session.load 二级缓存: 总的缓存.

  4. phpmyadmin数据库导入大小限制的修改

    1.遇到导入过大文件时,首先检查php.ini 配置文件中的以下三个地方,upload_max_filesize, memory_limit 和post_max_size,并且推荐修改的值要稍大于导入 ...

  5. 利用智能手机(Android)追踪一块磁铁(转)

    利用智能手机(Android)追踪一块磁铁(一) 利用智能手机(Android)追踪一块磁铁(二) 利用智能手机(Android)追踪一块磁铁(三)

  6. AFNetWorking发送post请求,Code=-1016错误

    使用AFNetWorking发送post请求时,可能会出现下面Code=-1016问题.打印的error如下: Error:Error Domain=com.alamofire.error.seria ...

  7. jstree使用小结(三)

    操作节点的这几个事件都比较简单: 如下 var $tree=$('#tree1'); $tree.jstree({...}); //选中节点 $tree.on('select_node.jstree' ...

  8. STM32中的位带(bit-band)操作(转)

    源:STM32中的位带(bit-band)操作 支持了位带操作后,可以使用普通的加载/存储指令来对单一的比特进行读写.在 CM3 中,有两个区中实现了位带.其中一个是 SRAM 区的最低 1MB 范围 ...

  9. ajax 基础2

    连接数据库实现分页功能 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Defa ...

  10. ios页面跳转

    reference:http://blog.csdn.net/engandend/article/details/11706323 目前,就我所学到的内容,页面跳转有三种方法 一.直接推到下一个页面 ...