您好,登錄后才能下訂單哦!
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的使用場景有哪些的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。