Java基础:集合List、Map、Set(超详细版)

发布于:2025-04-14 ⋅ 阅读:(21) ⋅ 点赞:(0)

集合体系概述

在这里插入图片描述
在这里插入图片描述

Collection常用方法

在这里插入图片描述
补充:addAll()

Collection的遍历方式

迭代器

在这里插入图片描述
在这里插入图片描述

增强for(空集合可以,null不可以)

在这里插入图片描述
在这里插入图片描述

lambda

在这里插入图片描述

集合对象存储对象原理

在这里插入图片描述

遍历方式的区别

在这里插入图片描述

List集合

特点、特有方法

在这里插入图片描述

遍历方式

(同上)

ArrayList底层原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

LinkedList底层原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

手写链表

/**
 * 手写链表
 */
public class MyLinkedList<E> {

    private int size = 0;
    Node<E> first;

    public static class Node<E> {
        E item;
        Node<E> next;
        public Node(E item, Node<E> next){
            this.item = item;
            this.next = next;
        }
    }

    public boolean add(E e) {
        Node<E> newNode = new Node<>(e, null);

        if(first == null) {
            first = newNode;
        } else {
            Node<E> temp = first;
            while(temp.next != null) {
                temp = temp.next;
            }
            temp.next = newNode;
        }

        size++;

        return true;
    }


    @Override
    public String toString() {
        StringJoiner s = new StringJoiner(",", "[", "]");
        Node<E> temp = first;
        while(temp != null) {
            s.add(temp.item + "");
            temp = temp.next;
        }
        return s.toString();
    }

    public int size(){
        return size;
    }

}

class Test {
    public static void main(String[] args) {
        MyLinkedList<String> list = new MyLinkedList<>();
        list.add("1号客人");
        list.add("2号客人");
        list.add("3号客人");
        list.add("4号客人");

        System.out.println(list);
    }
}

Set集合

特点

在这里插入图片描述

HashSet底层原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

了接下数据结构(树)

在这里插入图片描述
查询性能提高:排序
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

去重机制

在这里插入图片描述
在这里插入图片描述

LinkedHashSet底层原理-有序

在这里插入图片描述

TreeSet底层原理-排序

在这里插入图片描述
在这里插入图片描述

*优先选择

在这里插入图片描述

Map集合

概述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

常用方法

在这里插入图片描述

遍历方法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

HashMap-原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

LinkedHashMap-原理

在这里插入图片描述

TreeMap-原理

在这里插入图片描述