JAVA - ArrayList是否会越界?
JAVA - ArrayList是否会越界?
ArrayList并发add()可能出现数组下标越界异常。
ArrayList是实现了基于动态数组的数据结构。
LinkedList是基于链表的数据结构
对于随机访问get和set,ArrayList要优于LinkedList,因为LinkedList要移动指针;
扩展:在ArrayLIst和LinkedList尾部加元素,谁的效率高?
当输入的数据一直是小于千万级别的时候,大部分是LinkedList效率高,而当数据量大于千万级别的时候,就会出现ArrayList的效率比较高了。
原来 LinkedList每次增加的时候,会new 一个Node对象来存新增加的元素,所以当数据量小的时候,这个时间并不明显,而ArrayList需要扩容,所以LinkedList的效率就会比较高,其中如果ArrayList出现不需要扩容的时候,那么ArrayList的效率应该是比LinkedList高的,当数据量很大的时候,new对象的时间大于扩容的时间,那么就会出现ArrayList的效率比LinkedList高了
本文作者:护发师兄
本文链接:https://www.cnblogs.com/jonil/p/15904728.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
分类:
Java
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步