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

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

1、其他操作

2、数组操作

参考内容:

1、JDK源码(1.7)

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

1、ArrayList的其他操作和数组操作                                               

其他操作和数组操作

(1)Object clone()  , 关于java中的深拷贝和浅拷贝可以看看这里的介绍

功能: 返回此列表实例的浅复制

示例代码:

 1 import java.util.ArrayList;
 2 
 3 public class ArrayListTest {
 4     public static void main(String[] args) {
 5         ArrayList<Integer> list = new ArrayList<Integer>();
 6         list.add(22);
 7         list.add(33);
 8         list.add(44);
 9         list.add(11);
10         list.add(15);
11         list.add(12);
12         list.add(7);
13         list.add(3);
14         System.out.println("list1 :" + list);
15         //测试ArrayList的'Object clone()'方法的使用
16         ArrayList<Integer> list2 =  (ArrayList<Integer>) list.clone();
17         System.out.println("list2 :" + list2);
18         System.out.println("-----------------");
19         list2.set(1, 3333);
20         System.out.println("list1 :" + list);
21         System.out.println("list2 :" + list2);
22     }
23 }
24 
25 运行结果:
26 list1 :[22, 33, 44, 11, 15, 12, 7, 3]
27 list2 :[22, 33, 44, 11, 15, 12, 7, 3]
28 -----------------
29 list1 :[22, 33, 44, 11, 15, 12, 7, 3]
30 list2 :[22, 3333, 44, 11, 15, 12, 7, 3]

源代码如下:

 1     public Object clone() {
 2         try {
 3             @SuppressWarnings("unchecked")
 4             //进行浅拷贝    
 5             ArrayList<E> v = (ArrayList<E>) super.clone();
 6             //为拷贝的新对象设置属性值
 7             v.elementData = Arrays.copyOf(elementData, size);
 8             v.modCount = 0;
 9             return v;
10         } catch (CloneNotSupportedException e) {
11             // this shouldn't happen, since we are Cloneable
12             throw new InternalError();
13         }
14     }

(2) void ensureCapaCity(int minCapacity)

功能:如有必要,增加此列表实例的容量,以确保它至少能够容纳最小容量参数所指定的元素数

源代码如下:

 1    /*
 2       确保列表容量足够
 3    */
 4    public void ensureCapacity(int minCapacity) {
 5         //如果参数minCapacity>0,则调用内部方法ensureCapacityInternal
 6         if (minCapacity > 0)
 7             ensureCapacityInternal(minCapacity);
 8     }
 9     
10     /*
11        内部私有方法,确保列表容量足够
12     */
13     private void ensureCapacityInternal(int minCapacity) {
14         //fast-fail机制标识加1
15         modCount++;
16         // overflow-conscious code
17         //参数minCapacity比当前列表容量大,则调用私有方法grow
18         if (minCapacity - elementData.length > 0)
19             grow(minCapacity);
20     }
21 
22     /*
23         内部私有方法,
24     */
25     private void grow(int minCapacity) {
26         // overflow-conscious code
27         //记录当前列表容量大小
28         int oldCapacity = elementData.length;
29         //计划扩容大小为原列表容量大小的1.5倍
30         int newCapacity = oldCapacity + (oldCapacity >> 1);
31         //如果计划扩容的值 比 参数minCapacity小,则用minCapacity的值作为扩展的大小
32         if (newCapacity - minCapacity < 0)
33             newCapacity = minCapacity;
34 
35         //检查扩容的容量是否大于 列表允许的最大容量
36         if (newCapacity - MAX_ARRAY_SIZE > 0)
37             newCapacity = hugeCapacity(minCapacity);
38         // minCapacity is usually close to size, so this is a win:
39         //调用java.util.Arrays的copyOf方法对原数组elementData进行复制,复制的长度为newCapacity
40         elementData = Arrays.copyOf(elementData, newCapacity);
41     }
42 
43     private static int hugeCapacity(int minCapacity) {
44         if (minCapacity < 0) // overflow
45             throw new OutOfMemoryError();
46         return (minCapacity > MAX_ARRAY_SIZE) ?
47             Integer.MAX_VALUE :
48             MAX_ARRAY_SIZE;
49     }

(3)void trimToSize()

功能:将此列表的容量调整为列表的当前元素个数

源代码如下:

 1 public void trimToSize() {
 2         //fast-fail机制标识加1
 3         modCount++;
 4         //记录原列表容量大小
 5         int oldCapacity = elementData.length;
 6         //如果列表中元素个数 小于 列表容量带下,则对列表容量进行缩小
 7         if (size < oldCapacity) {
 8             elementData = Arrays.copyOf(elementData, size);
 9         }
10     }

(4)Object[] toArray()

功能:按适当顺序返回包含此列表中所有元素的数组

源代码如下:

1     public Object[] toArray() {
2         return Arrays.copyOf(elementData, size);
3     }

(5)<T> T[] toArray(T[] a)

功能:按适当顺序返回包含此列表中所有元素的数组

源代码如下:

 1     @SuppressWarnings("unchecked")
 2     public <T> T[] toArray(T[] a) {
 3         if (a.length < size)
 4             // Make a new array of a's runtime type, but my contents:
 5             return (T[]) Arrays.copyOf(elementData, size, a.getClass());
 6         System.arraycopy(elementData, 0, a, 0, size);
 7         if (a.length > size)
 8             a[size] = null;
 9         return a;
10     }

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

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

 

posted @ 2017-02-07 21:01  火爆泡菜  阅读(317)  评论(0编辑  收藏  举报