ArrayList和LinkedList区别及使用场景代码解析

网友投稿 287 2023-02-25


ArrayList和LinkedList区别及使用场景代码解析

本文研究的主要是java编程中ArrayList和LinkedList区别及使用场景的相关内容,具体介绍如下。

1、ArrayList是基于数组实现的,其构造函数为:

private transient Object[] elementData;

private int size;

ArryList初始化时,elementData数组大小默认为10;

每次add()时,先调用ensureCapacity()保证数组不会溢出,如果此时已满,会扩展为数http://组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区别及使用场景代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java操作MongoDB数据库方法详解
下一篇:Bootstrap popover 实现鼠标移入移除显示隐藏功能方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~