教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

LinkedList集合對元素進(jìn)行增、查、刪操作

更新時(shí)間:2022年03月23日17時(shí)01分 來源:傳智教育 瀏覽次數(shù):

ArrayList集合在查詢元素時(shí)速度很快,但在增刪元素時(shí)效率較低,為了克服這種局限性,可以使用List接口的另一個(gè)實(shí)現(xiàn)類LinkedList。LinkedList集合內(nèi)部包含有兩個(gè)Node類型的first和last屬性維護(hù)一個(gè)雙向循環(huán)鏈表,在鏈表中的每一個(gè)元素都使用引用的方式來記住它的前一個(gè)元素和后一個(gè)元素,從而可以將所有的元素彼此連接起來。當(dāng)插入一個(gè)新元素時(shí),只需要修改元素之間的這種引用關(guān)系即可,刪除一個(gè)節(jié)點(diǎn)也是如此。正因?yàn)檫@樣的存儲(chǔ)結(jié)構(gòu),所以LinkedList集合對于元素的增刪操作表現(xiàn)出很高的效率,LinkedList集合添加元素和刪除元素的過程如圖所示。

在圖6-5中,通過兩張圖描述了LinkedList集合新增元素和刪除元素的過程。其中,左圖為新增一個(gè)元素,圖中的元素1和元素2在集合中彼此為前后關(guān)系,在它們之間新增一個(gè)元素時(shí),只需要讓元素1記住它后面的元素是新元素,讓元素2記住它前面的元素為新元素就可以了。右圖為刪除元素,要想刪除元素1和元素2之間的元素3,只需要讓元素1與元素2變成前后關(guān)系就可以了。LinkedList集合除了從接口Collection和List中繼承并實(shí)現(xiàn)了集合操作方法外,還專門針對元素的增刪操作定義了一些特有的方法,如下所示。

方法聲明 功能描述
void add(int index, E element 在此列表中指定的位置插入指定的元素。
void addFirst(Object o) 將指定元素插入集合的開頭
void addLast(Object o) 將指定元素添加到集合的結(jié)尾
Object getFirst(O 返回集合的第一個(gè)元素
Object getLast() 返回集合的最后一個(gè)元素
Object removeFirst() 移除并返回集合的第一個(gè)元素
Object removeLast() 移除并返回集合的最后一個(gè)元素
boolean offer(Object o) 將指定元素添加到集合的結(jié)尾
boolean offerFirst(Object o) 將指定元素添加到集合的開頭
boolean offerLast(Object o) 將指定元素添加到集合的結(jié)尾
Object peek() 獲取集合的第一個(gè)元素
Object peekFirst() 獲取集合的第一個(gè)元素
Object peekLast( 獲取集合的最后一個(gè)元素
Object poll(0 移除并返回集合的第一個(gè)元素
Object pollFirst() 移除并返回集合的第一個(gè)元素
Object pollLast() 移除并返回集合的最后一個(gè)元素
void push(Object o) 將指定元素添加到集合的開頭
Object pop0 移除并返回集合的第一個(gè)元素

上表中,列出的方法主要針對集合中的元素進(jìn)行增加、刪除和獲取操作,接下來通過一個(gè)案例來學(xué)習(xí)LinkedList中常用方法的使用,如文件所示。

文件Example02.java

import java.util.LinkedList;
public class Example02 {
    3 public static void main(String[] args) {
        // 創(chuàng)建LinkedList集合
        LinkedList link = new LinkedList();
        // 1、添加元素
        link.add("stu1");
        link.add("stu2");
        System.out.println(link); // 輸出集合中的元素
        link.offer("offer"); // 向集合尾部追加元素
        link.push("push"); // 向集合頭部添加元素
        System.out.println(link); // 輸出集合中的元素
        // 2、獲取元素
        Object object = link.peek(); //獲取集合第一個(gè)元素
        System.out.println(object); // 輸出集合中的元素
        // 3、刪除元素
        link.removeFirst(); // 刪除集合第一個(gè)元素
        link.pollLast(); // 刪除集合最后一個(gè)元素
        System.out.println(link);
        20
    }
    21
}

運(yùn)行結(jié)果如下圖所示。

在文件Example02.java首先創(chuàng)建了一個(gè)LinkedList集合,接著分別使用add()、offer()、push()方法向集合中插入元素,然后使用peek()方法獲取了集合的第一個(gè)元素,最后分別使用removeFirst()、pollLast()方法將集合中指定位置的元素移除,這樣就完成了元素的增、查、刪操作。由此可見,使用LinkedList對元素進(jìn)行增刪操作是非常便捷的。




猜你喜歡:

LinkedList整體結(jié)構(gòu)介紹和LinkedList源碼分析

java培訓(xùn):LinkedList的原理介紹

ArrayList和LinkedList的區(qū)別和聯(lián)系匯總

如何使用ArrayList集合的方法來存取元素?

傳智教育java后端開發(fā)培訓(xùn)課程

0 分享到:
和我們在線交談!