国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

ArrayList和LinkedList區別及使用場景代碼解析

2020-01-04 15:35:40
字體:
來源:轉載
供稿:網友

本文研究的主要是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區別及使用場景代碼解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 辽源市| 安福县| 鹿邑县| 房山区| 古田县| 车险| 夏邑县| 新巴尔虎右旗| 志丹县| 兴海县| 宁晋县| 库伦旗| 新乡市| 洞口县| 封开县| 会理县| 西吉县| 秦安县| 贞丰县| 德安县| 阿拉善盟| 高密市| 兴和县| 彭州市| 牡丹江市| 永宁县| 溆浦县| 平顺县| 龙游县| 克拉玛依市| 龙泉市| 孟津县| 榆树市| 阜阳市| 阳江市| 彭州市| 忻城县| 商丘市| 白银市| 成都市| 军事|