List、set、Map的底层实现原理
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/xzp_12345/article/details/79251174 本文主要是参考了网上一些对java集合讲解的比较详细博客进行归纳总结,下面对 java集合中几个比较常用的类归纳分析。 ArrayList实现原理要点概括 参考文献: http://zhangshixi.iteye.com/blog/674856l https://www.cnblogs.com/leesf456/p/5308358.html ArrayList是List接口的可变数组非同步实现,并允许包括null在内的所有元素。底层使用数组实现该集合是可变长度数组,数组扩容时,会将老数组中的元素重新拷贝一份到新的数组中,每次数组容量增长大约是其容量的1.5倍,这种操作的代价很高。采用了Fail-Fast机制,面对并发的修改时,迭代器很快就会完全失败,而不是冒着在将来某个不确定时间发生任意不确定行为的风险remove方法会让下标到数组末尾的元素向前移动一个单位,并把最后一位的值置空,方便GC LinkedList实现原理要点概括 参考文献: 1.http://www.cnblogs.com/ITtangtang/p/3948610.htmll 2