ArrayList集合初始化及擴(kuò)容方式
ArrayList集合初始化及擴(kuò)容
ArrayList 集合
1.默認(rèn)初始化容量為10(底層先創(chuàng)建了一個(gè)長(zhǎng)度為0的數(shù)組,當(dāng)添加第一個(gè)元素的時(shí)候,初始化容量為10)
2.集合底層為一個(gè)Object[]數(shù)組
3.構(gòu)造方法:
new ArrayList(); new ArrayList(20);
4.ArrayList集合的擴(kuò)容:原容量的1.5倍。
ArrayList集合的底層是數(shù)組,怎么優(yōu)化?
盡可能的減少擴(kuò)容。因?yàn)閿?shù)組擴(kuò)容效率比較低,建議在使用Arraylist集合的時(shí)候預(yù)估計(jì)元素的個(gè)數(shù),給定一個(gè)初始化容量。
5.數(shù)組優(yōu)點(diǎn):檢索效率比較高
6.數(shù)組缺點(diǎn):隨機(jī)增刪元素效率比較低
7.向數(shù)組末尾添加元素,效率很高,不受影響
8.面試官經(jīng)常問(wèn)的一個(gè)問(wèn)題:
這么多集合中,你用那個(gè)集合最多?
答:ArrayList集合
因?yàn)橥鶖?shù)組末尾添加元素,對(duì)效率不受影響。
另外,我們檢索查找某個(gè)元素的操作比較多。
package Collection;
import java.util.ArrayList;
import java.util.List;
/*
ArrayList 集合:
1.默認(rèn)初始化容量為10(底層先創(chuàng)建了一個(gè)長(zhǎng)度為0的數(shù)組,當(dāng)添加第一個(gè)元素的時(shí)候,初始化容量為10)
2.集合底層為一個(gè)Object[]數(shù)組
3.構(gòu)造方法:
new ArrayList();
new ArrayList(20);
4.ArrayList集合的擴(kuò)容:
原容量的1.5倍。
ArrayList集合的底層是數(shù)組,怎么優(yōu)化?
盡可能的減少擴(kuò)容。因?yàn)閿?shù)組擴(kuò)容效率比較低,建議在使用Arraylist集合的
時(shí)候預(yù)估計(jì)元素的個(gè)數(shù),給定一個(gè)初始化容量。
5.數(shù)組優(yōu)點(diǎn):
檢索效率比較高
6.數(shù)組缺點(diǎn):
隨機(jī)增刪元素效率比較低
7.向數(shù)組末尾添加元素,效率很高,不受影響
8.面試官經(jīng)常問(wèn)的一個(gè)問(wèn)題:
這么多集合中,你用那個(gè)集合最多?
答:ArrayList集合
因?yàn)橥鶖?shù)組末尾添加元素,對(duì)效率不受影響。
另外,我們檢索查找某個(gè)元素的操作比較多。
*/
public class ArrayLisTest01 {
public static void main(String[] args) {
List l1=new ArrayList();
//集合的size方法是獲取當(dāng)前集合元素的個(gè)數(shù),不是獲取集合的容量
System.out.println(l1.size());
List l2=new ArrayList(20);
System.out.println(l2.size());
}
}ArrayList擴(kuò)容機(jī)制(原理)
ArrayList擴(kuò)容的本質(zhì)就是計(jì)算出新的擴(kuò)容數(shù)組的size后實(shí)例化,并將原有數(shù)組內(nèi)容復(fù)制到新數(shù)組中去。(不是原數(shù)組,而是新數(shù)組然后給予數(shù)組對(duì)象地址)。
默認(rèn)情況下,新的容量會(huì)是原容量的1.5倍。 新容量=舊容量右移一位(相當(dāng)于除于2)在加上舊容量
ArrayList 的底層是用動(dòng)態(tài)數(shù)組來(lái)實(shí)現(xiàn)的。我們初始化一個(gè)ArrayList 集合還沒(méi)有添加元素時(shí),其實(shí)它是個(gè)空數(shù)組,只有當(dāng)我們添加第一個(gè)元素時(shí),內(nèi)部會(huì)調(diào)用擴(kuò)容方法并返回最小容量10,也就是說(shuō)ArrayList 初始化容量為10。
當(dāng)前數(shù)組長(zhǎng)度小于最小容量的長(zhǎng)度時(shí)(前期容量是10,當(dāng)添加第11個(gè)元素時(shí)就就擴(kuò)容),便開(kāi)始可以擴(kuò)容了,ArrayList 擴(kuò)容的真正計(jì)算是在一個(gè)grow()里面,新數(shù)組大小是舊數(shù)組的1.5倍,如果擴(kuò)容后的新數(shù)組大小還是小于最小容量,那新數(shù)組的大小就是最小容量的大小,后面會(huì)調(diào)用一個(gè)Arrays.copyof方法,這個(gè)方法是真正實(shí)現(xiàn)擴(kuò)容的步驟。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring boot開(kāi)發(fā)遇到坑之spring-boot-starter-web配置文件使用教程
Spring Boot支持容器的自動(dòng)配置,默認(rèn)是Tomcat,當(dāng)然我們也是可以進(jìn)行修改的。這篇文章給大家介紹了spring boot開(kāi)發(fā)遇到坑之spring-boot-starter-web配置文件使用教程,需要的朋友參考下吧2018-01-01
Apache?Commons?BeanUtils:?JavaBean操作方法
這篇文章主要介紹了Apache?Commons?BeanUtils:?JavaBean操作的藝術(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
Springboot使用Logback實(shí)現(xiàn)日志配置與異常記錄
默認(rèn)情況下,SpringBoot內(nèi)部使用logback作為系統(tǒng)日志實(shí)現(xiàn)的框架,將日志輸出到控制臺(tái),不會(huì)寫(xiě)到日志文件。本篇文章主要講解下如何自定義logabck.xml以及對(duì)logback文件中配置做一個(gè)詳解,需要的可以參考一下2022-11-11
Springboot容器級(jí)后置處理器BeanDefinitionRegistryPostProcessor
這篇文章主要介紹了Springboot容器級(jí)后置處理器BeanDefinitionRegistryPostProcessor,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-01-01
Java中的interrupted()和isInterrupted()
這篇文章主要介紹了Java中的interrupted()和isInterrupted()摸下面文章圍繞interrupted()和isInterrupted()的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容,需要的小伙伴樂(lè)意參考下面下面文章具體價(jià)紹,希望對(duì)大家有所幫助2021-11-11
JSON反序列化Long變Integer或Double的問(wèn)題及解決
這篇文章主要介紹了JSON反序列化Long變Integer或Double的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
springcloud實(shí)現(xiàn)注冊(cè)中心Eureka
這篇文章主要介紹了springcloud實(shí)現(xiàn)注冊(cè)中心Eureka,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02

