Collection单列集合、Map(Key - Value)双列集合,多继承实现。

Collection集合:

Collection、List、Set、Queue 全是接口

ArrayList、LinkedList、HashSet 全是实现类

LinkedList 双实现:List + Queue


1. 顶层:Collection 接口(单列根接口)

复制代码
public interface Collection<E> extends Iterable<E> {
    // 增
    boolean add(E e);
    // 删
    boolean remove(Object o);
    // 查大小
    int size();
    // 是否为空
    boolean isEmpty();
    // 是否包含
    boolean contains(Object o);
    // 清空
    void clear();
}

2. 三个子接口 继承 Collection

List 接口

复制代码
public interface List<E> extends Collection<E> {
    // 特有:根据索引增删改查
    E get(int index);
    E set(int index, E element);
    void add(int index, E element);
    E remove(int index);
}

Set 接口

复制代码
public interface Set<E> extends Collection<E> {
    // 完全继承Collection,无特有方法
    // 规则:不可重复、无索引
}

Queue 接口(队列)

复制代码
public interface Queue<E> extends Collection<E> {
    // 队列特有:入队、出队、队首
    boolean offer(E e);
    E poll();
    E peek();
}

3. 实现类源码( ArrayList / LinkedList)

ArrayList 实现 List

复制代码
public class ArrayList<E> implements List<E> {
    // 底层:Object[] 数组
    transient Object[] elementData;
    
    @Override
    public boolean add(E e) {
        // 数组扩容 + 尾插
    }
}

LinkedList 实现 List + Queue

复制代码
// 重点:同时实现两个接口
public class LinkedList<E> implements List<E>, Queue<E> {
    // 底层:双向链表节点
    private static class Node<E> {
        E item;
        Node<E> next;
        Node<E> prev;
    }
}

HashSet 实现 Set

复制代码
public class HashSet<E> implements Set<E> {
    // 底层本质:HashMap
}

4. 终极继承关系 代码版

复制代码
// 顶层
Collection
├─ List    → ArrayList、LinkedList
├─ Set     → HashSet
└─ Queue   → LinkedList、ArrayDeque

关键=

  1. Collection、List、Set、Queue → 全是接口
  2. ArrayList、LinkedList、HashSet → 全是实现类
  3. LinkedList 多实现implements List, Queue
  4. Map 不继承 Collection,单独一套

Map 顶层接口(和 Collection 平级,互不继承

复制代码
public interface Map<K,V> {
    // 增
    V put(K key, V value);
    // 查
    V get(Object key);
    // 删
    V remove(Object key);
    // 判空、大小
    int size();
    boolean isEmpty();
    boolean containsKey(Object key);
    boolean containsValue(Object value);

    // 三个集合视图(核心)
    Set<K> keySet();
    Collection<V> values();
    Set<Map.Entry<K,V>> entrySet();

    // 内部静态嵌套接口:键值对条目
    interface Entry<K,V> {
        K getKey();
        V getValue();
    }
}

常用实现类 源码结构

1. HashMap(日常最常用)

复制代码
public class HashMap<K,V> implements Map<K,V> {
    // 底层:数组+链表+红黑树
    transient Node<K,V>[] table;
}

2. LinkedHashMap(有序)

复制代码
public class LinkedHashMap<K,V> extends HashMap<K,V> implements Map<K,V> {
    // 保留插入顺序
}

3. TreeMap(排序)

复制代码
public class TreeMap<K,V> implements Map<K,V> {
    // 底层红黑树,key自动排序
}

全集架构 终极对照

复制代码
// 单列集合 根接口
Collection
├─ List
├─ Set
└─Queue

// 双列集合 根接口(平级!不继承Collection)
Map
├─ HashMap
├─ LinkedHashMap
└─ TreeMap

总结

  1. Collection → 单列:单个元素
  2. Map → 双列:key-value 键值对
  3. Map 和 Collection 完全平级,没有任何继承关系
  4. entrySet() 就是把每一组键值对封装成 Map.Entry
相关推荐
Anastasiozzzz1 小时前
从有限状态机到智能体图:传统 FSM 与 Agent Graph的演进
java·人工智能·python·ai
fqbqrr6 小时前
2606C++,C++构的多态
开发语言·c++
biter down7 小时前
从 0 到 1 搭建 Python 接口自动化测试框架(博客系统实战)
开发语言·python
wang09077 小时前
自己动手写一个spring之IOC_2
java·后端·spring
来杯@Java7 小时前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
sun0077008 小时前
SniffMaster(读取苹果的ats文件) 和 wireshark
windows
threelab8 小时前
Three.js 物理模拟着色器 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
武器大师728 小时前
lv_binding_js 代码解读
开发语言·javascript·ecmascript
不知名的老吴8 小时前
线程的生命周期之线程“插队“
java·开发语言·python