首页 > 编程语言 > 详细

Java的集合知识

时间:2021-04-11 16:02:08      阅读:14      评论:0      收藏:0      [点我收藏+]

ArrayList

  • 动态数组(可扩容数组),初始容量为10,扩容后为原容量的1.5倍
  • 用Collections.synchronizedList(new ArrayList())可以得到一个线程安全的ArrayList
    看一下ArrayList的grow()函数:
private void grow(int minCapacity) {
    // overflow-conscious code
    int oldCapacity = elementData.length;
    int newCapacity = oldCapacity + (oldCapacity >> 1);
    if (newCapacity - minCapacity < 0)
        newCapacity = minCapacity;
    if (newCapacity - MAX_ARRAY_SIZE > 0)
        newCapacity = hugeCapacity(minCapacity);
    // minCapacity is usually close to size, so this is a win:
    elementData = Arrays.copyOf(elementData, newCapacity);
}

如果,1.5倍的容量还不够,就直接拿minCapacity赋值给newCapacity。
如果,新容量太大,超过了MAX_ARRAY_SIZE,则最大最大只能是Integer.MAX_VALUE

LinkedList

  • 双向链表

Java的集合知识

原文:https://www.cnblogs.com/zyk98/p/14643534.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!