Java Collection子接口: List接口

List接口概述

  • 鑒于Java中數(shù)組用來存儲(chǔ)數(shù)據(jù)的局限性蛀恩,我們通常使用List替代數(shù)組
  • List集合類中元素有序领迈、且可重復(fù)算吩,集合中的每個(gè)元素都有其對(duì)應(yīng)的順序索引拓萌。
  • List容器中的元素都對(duì)應(yīng)一個(gè)整數(shù)型的序號(hào)記載其在容器中的位置岁钓,可以根據(jù)序號(hào)存取容器中的元素。
  • JDK API中List接口的實(shí)現(xiàn)類常用的有:ArrayList微王、LinkedList和Vector屡限。

List接口方法

  1. 增:
    void add(int index, Object ele):在index位置插入ele元素。
    boolean addAll(int index, Collection eles):從index位置開始將eles中的所有元素添加進(jìn)來炕倘。
  2. 刪:
    Object remove(int index):移除指定index位置的元素钧大,并返回此元素
  3. 改:
    Object set(int index, Object ele):設(shè)置指定index位置的元素為ele
    1.查:
    Object get(int index):獲取指定index位置的元素
    int indexOf(Object obj):返回obj在集合中首次出現(xiàn)的位置
    int lastIndexOf(Object obj):返回obj在當(dāng)前集合中末次出現(xiàn)的位置
    List subList(int fromIndex, int toIndex):返回從fromIndex到toIndex
    位置的子集合

List實(shí)現(xiàn)類之一:ArrayList

本質(zhì)上,ArrayList是對(duì)象引用的一個(gè)”變長(zhǎng)”數(shù)組

ArrayList的JDK1.8之前與之后的實(shí)現(xiàn)區(qū)別罩旋?

  • JDK1.7:ArrayList像餓漢式啊央,直接創(chuàng)建一個(gè)初始容量為10的數(shù)組
  • JDK1.8:ArrayList像懶漢式,一開始創(chuàng)建一個(gè)長(zhǎng)度為0的數(shù)組涨醋,當(dāng)添加第一個(gè)元素時(shí)再創(chuàng)建一個(gè)始容量為10的數(shù)組
    Arrays.asList() 方法返回的 List 集合瓜饥,既不是 ArrayList 實(shí)例,也不是Vector 實(shí)例浴骂。 Arrays.asList() 返回值是一個(gè)固定長(zhǎng)度的 List 集合

List實(shí)現(xiàn)類之二:LinkedList

LinkedList:雙向鏈表乓土,內(nèi)部沒有聲明數(shù)組,而是定義了Node類型的first和last溯警,用于記錄首末元素趣苏。同時(shí),定義內(nèi)部類Node梯轻,作為L(zhǎng)inkedList中保存數(shù)據(jù)的基本結(jié)構(gòu)食磕。Node除了保存數(shù)據(jù),還定義了兩個(gè)變量:

List 實(shí)現(xiàn)類之三:Vector

Vector 是一個(gè)古老的集合喳挑,JDK1.0就有了芬为。大多數(shù)操作與ArrayList相同,區(qū)別之處在于Vector是線程安全的蟀悦。
在各種list中媚朦,最好把ArrayList作為缺省選擇。當(dāng)插入日戈、刪除頻繁時(shí)询张,使用LinkedList;Vector總是比ArrayList慢浙炼,所以盡量避免使用份氧。

ArrayList/LinkedList/Vector的異同

ArrayList和LinkedList的異同:
二者都線程不安全唯袄,相對(duì)線程安全的Vector,執(zhí)行效率高蜗帜。
此外恋拷,ArrayList是實(shí)現(xiàn)了基于動(dòng)態(tài)數(shù)組的數(shù)據(jù)結(jié)構(gòu),LinkedList基于鏈表的數(shù)據(jù)結(jié)構(gòu)厅缺。對(duì)于隨機(jī)訪問get和set蔬顾,ArrayList覺得優(yōu)于LinkedList,因?yàn)長(zhǎng)inkedList要移動(dòng)指針湘捎。對(duì)于新增和刪除操作add(特指插入)和remove诀豁,LinkedList比較占優(yōu)勢(shì),因?yàn)锳rrayList要移動(dòng)數(shù)據(jù)窥妇。
ArrayList和Vector的異同:
Vector和ArrayList幾乎是完全相同的,唯一的區(qū)別在于Vector是同步類(synchronized)舷胜,屬于強(qiáng)同步類。因此開銷就比ArrayList要大活翩,訪問要慢烹骨。正常情況下,大多數(shù)的Java程序員使用ArrayList而不是Vector,因?yàn)橥酵耆梢杂沙绦騿T自己來控制。Vector每次擴(kuò)容請(qǐng)求其大小的2倍空間材泄,而ArrayList是1.5倍展氓。Vector還有一個(gè)子類Stack。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末脸爱,一起剝皮案震驚了整個(gè)濱河市遇汞,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌簿废,老刑警劉巖空入,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異族檬,居然都是意外死亡歪赢,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門单料,熙熙樓的掌柜王于貴愁眉苦臉地迎上來埋凯,“玉大人,你說我怎么就攤上這事扫尖“锥裕” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵换怖,是天一觀的道長(zhǎng)甩恼。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么条摸? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任悦污,我火速辦了婚禮,結(jié)果婚禮上钉蒲,老公的妹妹穿的比我還像新娘切端。我一直安慰自己,他們只是感情好顷啼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布踏枣。 她就那樣靜靜地躺著,像睡著了一般线梗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上怠益,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天仪搔,我揣著相機(jī)與錄音,去河邊找鬼蜻牢。 笑死烤咧,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的抢呆。 我是一名探鬼主播煮嫌,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼抱虐!你這毒婦竟也來了昌阿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤恳邀,失蹤者是張志新(化名)和其女友劉穎懦冰,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谣沸,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刷钢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了乳附。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片内地。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖赋除,靈堂內(nèi)的尸體忽然破棺而出阱缓,到底是詐尸還是另有隱情,我是刑警寧澤举农,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布茬祷,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏祭犯。R本人自食惡果不足惜秸妥,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望沃粗。 院中可真熱鬧粥惧,春花似錦、人聲如沸最盅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)涡贱。三九已至咏删,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間问词,已是汗流浹背督函。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留激挪,地道東北人辰狡。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像垄分,于是被迫代替她去往敵國(guó)和親宛篇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355