LinkedList介绍以及常用方法

package com.itheima.demo01.List;

import java.util.LinkedList;

/*

java.util.LinkedList集合 implements List接口
LinkedList集合的特点:
    1.底层是一个链表结构:查询慢,增删快
    2.里边包含了大量操作首尾元素的方法
    注意:使用LinkedList集合特有的方法,不能使用多态

    - public void addFirst(E e):将指定元素插入此列表的开头。
    - public void addLast(E e):将指定元素添加到此列表的结尾。
    - public void push(E e):将元素推入此列表所表示的堆栈。

    - public E getFirst():返回此列表的第一个元素。
    - public E getLast():返回此列表的最后一个元素。

    - public E removeFirst():移除并返回此列表的第一个元素。
    - public E removeLast():移除并返回此列表的最后一个元素。
    - public E pop():从此列表所表示的堆栈处弹出一个元素。

    - public boolean isEmpty():如果列表不包含元素,则返回true。

*/
public class Demo02LinkedList {

public static void main(String[] args) {
    show03();
}

/*
    - public E removeFirst():移除并返回此列表的第一个元素。
    - public E removeLast():移除并返回此列表的最后一个元素。
    - public E pop():从此列表所表示的堆栈处弹出一个元素。此方法相当于 removeFirst
 */
private static void show03() {
    //创建LinkedList集合对象
    LinkedList<String> linked = new LinkedList<>();
    //使用add方法往集合中添加元素
    linked.add("a");
    linked.add("b");
    linked.add("c");
    System.out.println(linked);//[a, b, c]

    //String first = linked.removeFirst();
    String first = linked.pop();
    System.out.println("被移除的第一个元素:"+first);
    String last = linked.removeLast();
    System.out.println("被移除的最后一个元素:"+last);
    System.out.println(linked);//[b]
}

/*
    - public E getFirst():返回此列表的第一个元素。
    - public E getLast():返回此列表的最后一个元素。
 */
private static void show02() {
    //创建LinkedList集合对象
    LinkedList<String> linked = new LinkedList<>();
    //使用add方法往集合中添加元素
    linked.add("a");
    linked.add("b");
    linked.add("c");

    //linked.clear();//清空集合中的元素 在获取集合中的元素会抛出NoSuchElementException

    //public boolean isEmpty():如果列表不包含元素,则返回true。
    if(!linked.isEmpty()){
        String first = linked.getFirst();
        System.out.println(first);//a
        String last = linked.getLast();
        System.out.println(last);//c
    }
}

/*
    - public void addFirst(E e):将指定元素插入此列表的开头。
    - public void addLast(E e):将指定元素添加到此列表的结尾。
    - public void push(E e):将元素推入此列表所表示的堆栈。此方法等效于 addFirst(E)。
 */
private static void show01() {
    //创建LinkedList集合对象
    LinkedList<String> linked = new LinkedList<>();
    //使用add方法往集合中添加元素
    linked.add("a");
    linked.add("b");
    linked.add("c");
    System.out.println(linked);//[a, b, c]

    //public void addFirst(E e):将指定元素插入此列表的开头。
    //linked.addFirst("www");
    linked.push("www");
    System.out.println(linked);//[www, a, b, c]

    //public void addLast(E e):将指定元素添加到此列表的结尾。此方法等效于 add()
    linked.addLast("com");
    System.out.println(linked);//[www, a, b, c, com]
}
/*

boolean add(E e)

      将指定元素添加到此列表的结尾。 

void add(int index, E element)

      在此列表中指定的位置插入指定的元素。 

boolean addAll(Collection<? extends E> c)

      添加指定 collection 中的所有元素到此列表的结尾,顺序是指定 collection 的迭代器返回这些元素的顺序。 

boolean addAll(int index, Collection<? extends E> c)

      将指定 collection 中的所有元素从指定位置开始插入此列表。 

void addFirst(E e)

      将指定元素插入此列表的开头。 

void addLast(E e)

      将指定元素添加到此列表的结尾。 

void clear()

      从此列表中移除所有元素。 

Object clone()

      返回此 LinkedList 的浅表副本。 

boolean contains(Object o)

      如果此列表包含指定元素,则返回 true。 

Iterator<E> descendingIterator()

      返回以逆向顺序在此双端队列的元素上进行迭代的迭代器。 

E element()

      获取但不移除此列表的头(第一个元素)。 

E get(int index)

      返回此列表中指定位置处的元素。 

E getFirst()

      返回此列表的第一个元素。 

E getLast()

      返回此列表的最后一个元素。 

int indexOf(Object o)

      返回此列表中首次出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1。 

int lastIndexOf(Object o)

      返回此列表中最后出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1。 

ListIterator<E> listIterator(int index)

      返回此列表中的元素的列表迭代器(按适当顺序),从列表中指定位置开始。 

boolean offer(E e)

      将指定元素添加到此列表的末尾(最后一个元素)。 

boolean offerFirst(E e)

      在此列表的开头插入指定的元素。 

boolean offerLast(E e)

      在此列表末尾插入指定的元素。 

E peek()

      获取但不移除此列表的头(第一个元素)。 

E peekFirst()

      获取但不移除此列表的第一个元素;如果此列表为空,则返回 null。 

E peekLast()

      获取但不移除此列表的最后一个元素;如果此列表为空,则返回 null。 

E poll()

      获取并移除此列表的头(第一个元素) 

E pollFirst()

      获取并移除此列表的第一个元素;如果此列表为空,则返回 null。 

E pollLast()

      获取并移除此列表的最后一个元素;如果此列表为空,则返回 null。 

E pop()

      从此列表所表示的堆栈处弹出一个元素。 

void push(E e)

      将元素推入此列表所表示的堆栈。 

E remove()

      获取并移除此列表的头(第一个元素)。 

E remove(int index)

      移除此列表中指定位置处的元素。 

boolean remove(Object o)

      从此列表中移除首次出现的指定元素(如果存在)。 

E removeFirst()

      移除并返回此列表的第一个元素。 

boolean removeFirstOccurrence(Object o)

      从此列表中移除第一次出现的指定元素(从头部到尾部遍历列表时)。 

E removeLast()

      移除并返回此列表的最后一个元素。 

boolean removeLastOccurrence(Object o)

      从此列表中移除最后一次出现的指定元素(从头部到尾部遍历列表时)。 

E set(int index, E element)

      将此列表中指定位置的元素替换为指定的元素。 

int size()

      返回此列表的元素数。 

Object[] toArray()

      返回以适当顺序(从第一个元素到最后一个元素)包含此列表中所有元素的数组。 

<T> T[]
toArray(T[] a)

      返回以适当顺序(从第一个元素到最后一个元素)包含此列表中所有元素的数组;返回数组的运行时类型为指定数组的类型。 

*/

}

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理