Java——集合中的List接口通过LinkedList类实现一些常用的方法

简介: Java——集合中的List接口通过LinkedList类实现一些常用的方法

任何复杂的知识往往给人的感觉都是那么的不友好,所以,一定要静下心来,耐心去看、去读、去理解这些东西!!!  


1.开篇


https://blog.csdn.net/weixin_43823808/article/details/107297465


https://blog.csdn.net/weixin_43823808/article/details/107298333


因为在以上这两篇博文中,我已经介绍了 Java 集合中的 Collection、List 接口通过 ArrayList 类来实现一些常用的方法,那么,在这篇博文中,我来介绍 Collection、List 接口中另一个实现类(LinkedList)的一些常用方法。


2.LinkedList类简介


LinkedList List 接口的另一个实现类,LinkedList 内部包含有两个 Node 类型的 first last 属性双向循环链表结构 。

由于LinkedList的存储结构, LinkedList集合对于元素的遍历和查找效率较低;LinkedList集合对于元素的增删操作表现出很高的效率。(这个特点和 ArrayList 类是刚好相反的)


3.LinkedList类的特有方法


 

4.应用举例


import java.util.*;
/*import java.util.LinkedList;
  import java.util.ArrayList;
  import java.util.Iterator;*/
public class LinkedListDemo {
  public static void main(String[] args) {
    LinkedList<String> link=new LinkedList<String>();//创建LinkedList链表集合对象
    System.out.println("↓↓↓LinkedList集合常用方法如下↓↓↓");
    System.out.println("---------------------------------------------");
    System.out.println("创建第一个空的LinkedList集合,元素类型为String类:" + link);
    System.out.println("---------------------------------------------");
    link.add(0,"链表元素0");
    link.add(1,"链表元素1");
    link.add(2,"链表元素2");
    link.add(3,"链表元素3");
    System.out.println("向link集合中指定位置添加4个元素:" + link);
    link.addFirst("开头");
    link.addLast("结尾");
    System.out.println("向link集合的开头和结尾添加元素:" + link);
    System.out.println("---------------------------------------------");
    String first1=link.getFirst();
    String last1=link.getLast();
    String end1=link.get(2);
    System.out.println("获取link集合的第一个元素:" + first1);
    System.out.println("获取link集合的最后一个元素:" + last1);
    System.out.println("获取link集合中索引为2的元素:" + end1);
    System.out.println("---------------------------------------------");
    String first2=link.removeFirst();
    String last2=link.removeLast();
    System.out.println("移除link集合中的第一个和最后一个元素:" + first2 + " " + last2);
    System.out.println("移除之后的link集合为:" + link);
    System.out.println("---------------------------------------------");
    link.offer("链表元素4");
    link.offerFirst("开头");
    link.offerLast("结尾");
    System.out.println("添加指定元素之后的link集合为:" + link);
    System.out.println("---------------------------------------------");
    System.out.println("两种方法获取link集合的第一个元素:" + link.peek() + " " + link.peekFirst());
    System.out.println("获取link集合的最后一个元素:" + link.peekLast());
    System.out.println("---------------------------------------------");
    System.out.println("移除并返回link集合的第一个元素:" + link.poll());
    System.out.println("移除并返回link集合的第一个元素:" + link.pollFirst());
    System.out.println("移除并返回link集合的最后一个元素:" + link.pollLast());
    System.out.println("移除之后的link集合为:" + link);
    System.out.println("---------------------------------------------");
    link.push("链表元素0");
    System.out.println("添加指定元素之后的link集合为:" + link);
    System.out.println("---------------------------------------------");
    String first3=link.pop();
    System.out.println("移除并返回link集合的第一个元素:" + first3);
    System.out.println("移除之后的link集合为:" + link);
    System.out.println("---------------------------------------------");
    System.out.print("将link集合转为数组,并将元素存入数组中:");
    System.out.print("使用for-each循环遍历link集合中的所有元素:");
    for(Object a : link) {
      System.out.print(a + " ");
    }
    System.out.println();
    System.out.println("---------------------------------------------");
    //第一步:使用集合中的iterator()方法,获取送代器的实现类对象
                //第二步:使用Iterator接口接收(多态)
    Iterator iterator=link.iterator();
    while(iterator.hasNext()) {
      /*第三步:使用Iterator接口中的hasNext()方法来判断集合中还有没有下一个元素
        如果有下一个元素,那么就调用Iterator接口的next()方法,取出下一个元素,并且会把指针向后移一位
        第四步:使用Iterator接口中的next()方法来取出集合中的下一个元素
        以此类推,直到hasNext()方法返回false,表示到达了集合的末尾终止对元素的遍历*/
      System.out.print(iterator.next() + " ");
    }
    System.out.println();
    System.out.println("---------------------------------------------");
  }
}



相关文章
|
3月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
153 4
|
3月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
235 5
|
3月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
230 1
|
3月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
283 1
|
3月前
|
存储 Java 程序员
【Java】(6)全方面带你了解Java里的日期与时间内容,介绍 Calendar、GregorianCalendar、Date类
java.util 包提供了 Date 类来封装当前的日期和时间。Date 类提供两个构造函数来实例化 Date 对象。第一个构造函数使用当前日期和时间来初始化对象。Date( )第二个构造函数接收一个参数,该参数是从1970年1月1日起的毫秒数。
225 1
|
Java
Java中List排序的3种方法!(5)
Java中List排序的3种方法!(5)
451 0
Java中List排序的3种方法!(5)
|
Java
Java中List排序的3种方法!(4)
Java中List排序的3种方法!(4)
416 0
Java中List排序的3种方法!(4)
|
Java
Java中List排序的3种方法!(3)
Java中List排序的3种方法!(3)
428 0
Java中List排序的3种方法!(3)
|
Java
Java中List排序的3种方法!(2)
Java中List排序的3种方法!(2)
262 0
Java中List排序的3种方法!(2)
|
Java
Java中List排序的3种方法!(1)
Java中List排序的3种方法!(1)
588 0
Java中List排序的3种方法!(1)