一、ArrayList分析

1.类和构造方法

public class ArrayList<E> extends AbstractList<E>  //可以看到其父类是AbstractList
implements List<E>, RandomAccess, Cloneable, java.io.Serializable
{
private static final long serialVersionUID = 8683452581122892189L; private static final int DEFAULT_CAPACITY = ; //默认数组长度

//用于空实例的共享空数组实例。
private static final Object[] EMPTY_ELEMENTDATA = {}; //底层是Object类型的数组

//共享空数组实例用于默认大小的空实例。我们将其与EMPTY_ELEMENTDATA区别开来,以便知道当添加第一个元素时膨胀多少。
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};

//存储ArrayList元素的数组缓冲区。
//ArrayList的容量是这个数组缓冲区的长度。
//当添加第一个元素时,任何带有elementData==DEFAULTCAPACITY_EMPTY_ELEMENTDATA的空ArrayList将被扩展为DEFAULT_CAPACITY。
transient Object[] elementData; // 非私有以简化嵌套类访问 private int size; //数组内数据元素的个数 public ArrayList(int initialCapacity) {
//我们在声明实例的时候可以指定容量大小,若为0的话,则使用ELEMENTDATA作为默认数组。
if (initialCapacity > ) {
this.elementData = new Object[initialCapacity];
} else if (initialCapacity == ) {
this.elementData = EMPTY_ELEMENTDATA;
} else {
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
}
} public ArrayList() { //若不指定容量大小,则使用DEFAULTCAPACITY_EMPTY_ELEMENTDATA作为默认数组
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
} public ArrayList(Collection<? extends E> c) { //也可以接收Clooection类型的变量,把里面的元素拷贝到数组里面
elementData = c.toArray();
if ((size = elementData.length) != ) {
// c.toArray might (incorrectly) not return Object[] (see 6260652)
if (elementData.getClass() != Object[].class)
elementData = Arrays.copyOf(elementData, size, Object[].class);
} else {
// replace with empty array.
this.elementData = EMPTY_ELEMENTDATA;
}
}
}

2.add()方法

 public boolean add(E e) { //在存入数据前,先确保内部容量
ensureCapacityInternal(size + ); // Increments modCount!!
elementData[size++] = e;
return true;
}
private void ensureCapacityInternal(int minCapacity) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity); // 默认容量10和当前容量取max
}
ensureExplicitCapacity(minCapacity); //校验当前容量是否符合要求容量
}
private void ensureExplicitCapacity(int minCapacity) {
modCount++;
// overflow-conscious code
if (minCapacity - elementData.length > )
grow(minCapacity); // 如果要求容量大于数组容量,就扩容
}
private void grow(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> ); // 新容量 = 旧容量+旧容量的一半
if (newCapacity - minCapacity < )
newCapacity = minCapacity;
if (newCapacity - MAX_ARRAY_SIZE > )
newCapacity = hugeCapacity(minCapacity);
// minCapacity is usually close to size, so this is a win:
elementData = Arrays.copyOf(elementData, newCapacity); // 把旧数据拷贝到新数组里面
}

二、Vector分析(线程安全的)

1.类和构造方法

public class Vector<E>
extends AbstractList<E>
implements List<E>, RandomAccess, Cloneable, java.io.Serializable
{ protected Object[] elementData; protected int elementCount; protected int capacityIncrement; private static final long serialVersionUID = -2767605614048989439L; public Vector(int initialCapacity, int capacityIncrement) {
super();
if (initialCapacity < )
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
this.elementData = new Object[initialCapacity];
this.capacityIncrement = capacityIncrement;
} public Vector(int initialCapacity) {
this(initialCapacity, );
} public Vector() {
this();
} public Vector(Collection<? extends E> c) {
elementData = c.toArray();
elementCount = elementData.length;
// c.toArray might (incorrectly) not return Object[] (see 6260652)
if (elementData.getClass() != Object[].class)
elementData = Arrays.copyOf(elementData, elementCount, Object[].class);
}
}

2.add()方法

public synchronized boolean add(E e) {
modCount++;
ensureCapacityHelper(elementCount + ); // 先校验容量
elementData[elementCount++] = e;
return true;
}
private void ensureCapacityHelper(int minCapacity) {
// overflow-conscious code
if (minCapacity - elementData.length > )
grow(minCapacity); //扩容
}
private void grow(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + ((capacityIncrement > ) ?
capacityIncrement : oldCapacity);
if (newCapacity - minCapacity < )
newCapacity = minCapacity;
if (newCapacity - MAX_ARRAY_SIZE > )
newCapacity = hugeCapacity(minCapacity);
elementData = Arrays.copyOf(elementData, newCapacity);
}
private static int hugeCapacity(int minCapacity) {
        if (minCapacity < 0) // overflow
            throw new OutOfMemoryError();
        return (minCapacity > MAX_ARRAY_SIZE) ?
            Integer.MAX_VALUE :
            MAX_ARRAY_SIZE;
}

 三、LinkedList

1.类和构造方法

public class LinkedList<E>
extends AbstractSequentialList<E>
implements List<E>, Deque<E>, Cloneable, java.io.Serializable
{
transient int size = ;
transient Node<E> first; //头结点
transient Node<E> last; //尾结点 public LinkedList() {
}
public LinkedList(Collection<? extends E> c) {
this();
addAll(c);
} private static class Node<E> { //底层是双向链表
E item;
Node<E> next;
Node<E> prev; Node(Node<E> prev, E element, Node<E> next) {
this.item = element;
this.next = next;
this.prev = prev;
}
} }

2.add()方法

public boolean add(E e) {//add方法就是在链表的尾部加上一个结点
linkLast(e);
return true;
}
void linkLast(E e) {
final Node<E> l = last;
final Node<E> newNode = new Node<>(l, e, null);
last = newNode;
if (l == null)
first = newNode;
else
l.next = newNode;
size++;
modCount++;
}

3.get()方法

public E get(int index) {
checkElementIndex(index);
return node(index).item;
}
private void checkElementIndex(int index) {
if (!isElementIndex(index))
throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
}
Node<E> node(int index) {
// assert isElementIndex(index);
// 若索引在链表的前半部分,就从前往后取;否则从后往前取
if (index < (size >> )) {
Node<E> x = first;
for (int i = ; i < index; i++)
x = x.next;
return x;
} else {
Node<E> x = last;
for (int i = size - ; i > index; i--)
x = x.prev;
return x;
}
}

最新文章

  1. Bootstrap之BootstrapDialog
  2. (转载)RESTORE DATABASE命令还原SQLServer 2005 数据库
  3. ICE系列之3对象接口定义语言——slice
  4. Definition Questions
  5. PDO讲解
  6. Zero_qiqi DIV模式的省市区三级联动
  7. kuangbin_ShortPath G (POJ 1502)
  8. opencv 手写选择题阅卷 (三)训练分类器
  9. C#中的多线程使用 -- Thread 类详解(转)
  10. Oracle清除数据库中长时间占用资源的非活动的会话
  11. BEGINNING SHAREPOINT&amp;#174; 2013 DEVELOPMENT 第8章节--配送SP2013Apps
  12. python中文编码坑
  13. ViewPager实现首次进入软件时左右滑屏的软件展示效果
  14. MySQL管理实务处理
  15. 【bzoj5004】开锁魔法II 组合数学+概率dp
  16. [转载]eclipse自动同步插件filesync的使用
  17. java 5.0引入的新特性-枚举
  18. Spring的AOP编程
  19. 【HTML-进阶-如何实现父级块级元素宽度自适应子元素宽度】
  20. 02、Windows Phone 套接字(Socket)实战之服务器端设计

热门文章

  1. zookeeper3.4.5集群安装
  2. 搭建Mac OS X下cocos2d-x的Android开发环境
  3. CodeForces - 987E Petr and Permutations (思维+逆序对)
  4. POJ - 2762 Going from u to v or from v to u? (强连通缩点+判断单向连通)
  5. angularjs中directive声明scope对象的用法
  6. 20145219 《Java程序设计》实验三 敏捷开发与XP实践
  7. Spring_使用 NamedParameterJdbcTemplate
  8. Servlet容器初始化IOC容器
  9. 八步学会数据迁移:ETL工具kettle使用方法
  10. tomcat配置访问图片路径映射到磁盘路径