ArrayList和LinkedList区别及使用场景代码解析
2018-01-24 08:45
801 查看
本文研究的主要是Java编程中ArrayList和LinkedList区别及使用场景的相关内容,具体介绍如下。
1、ArrayList是基于数组实现的,其构造函数为:
private transient Object[] elementData; private int size;
ArryList初始化时,elementData数组大小默认为10;
每次add()时,先调用ensureCapacity()保证数组不会溢出,如果此时已满,会扩展为数组length的1.5倍+1,然后用array.copy的方法,将原数组拷贝到新的数组中;
ArrayList线程不安全,Vector方法是同步的,线程安全;
2、LinkedList是基于双链表实现的:
Object element; Entry next, previous;
初始化时,有个header Entry,值为null;
使用header的优点是:在任何一个条目(包括第一个和最后一个)都有一个前置条目和一个后置条目,因此在LinkedList对象的开始或者末尾进行插入操作没有特殊的地方;
使用场景:
(1)如果应用程序对各个索引位置的元素进行大量的存取或删除操作,ArrayList对象要远优于LinkedList对象;
( 2 ) 如果应用程序主要是对列表进行循环,并且循环时候进行插入或者删除操作,LinkedList对象要远优于ArrayList对象。
总结
以上就是本文关于ArrayList和LinkedList区别及使用场景代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
您可能感兴趣的文章:
相关文章推荐
- ArrayList和LinkedList区别及使用场景
- Java 集合系列 07 List总结(LinkedList, ArrayList等使用场景和性能分析)
- ArrayList和LinkedList的区别解析
- Java 集合系列08之 List总结(LinkedList, ArrayList等使用场景和性能分析)
- Java 集合系列08之 List总结(LinkedList, ArrayList等使用场景和性能分析)
- LinkedList, ArrayList等使用场景和性能分析)
- Java 集合系列08之 List总结(LinkedList, ArrayList等使用场景和性能分析)
- ArrayList,LinkedList使用场景及性能说明
- 【转】LinkedList、ArrayList各自的使用场景分析
- [转载] ArrayList Vector LinkedList 区别与用法 以及对 List,Map,Set 的解析
- ArrayList 和 LinkedList 和Vector使用上有什么区别?实现上有什么区别?
- 什么场景下更适宜使用LinkedList,而不用ArrayList。
- ArrayList 和 LinkedList 和Vector使用上有什么区别?实现上有什么区别?
- Java 集合系列08之 List总结(LinkedList, ArrayList等使用场景和性能分析)
- LinkedList和ArrayList的使用场景
- Java集合系列:-----------06List的总结(LinkedList,ArrayList等使用场景和性能分析)
- 安卓 ArrayList,LinkedList,HashSet,Vector,TreeSet的区别和使用
- Java 集合系列之 List总结(LinkedList, ArrayList等使用场景和性能分析)
- LinkedList和ArrayList的区别/何时使用LinkedList和ArrayList
- Java 集合系列08之 List总结(LinkedList, ArrayList等使用场景和性能分析)