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

集合体系概述


Collection常用方法

补充:addAll()

Collection的遍历方式

迭代器


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


lambda

集合对象存储对象原理

遍历方式的区别

List集合

特点、特有方法

遍历方式

(同上)

ArrayList底层原理



LinkedList底层原理



手写链表

java 复制代码
/**
 * 手写链表
 */
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-原理

相关推荐
liuyao_xianhui2 分钟前
优选算法_判断字符是否唯一_C++
java·开发语言·数据结构·c++·算法·链表
代码雕刻家6 分钟前
3.4.Maven-idea集成-导入Maven项目
java·maven·intellij-idea
no_work8 分钟前
python-深度学习快速入门实战-数据集和源码
开发语言·人工智能·python·深度学习·神经网络·cnn
Yupureki9 分钟前
《C++实战项目-高并发内存池》7.大块内存的申请与释放
服务器·c语言·开发语言·c++·算法·哈希算法
2301_8035545211 分钟前
c++中的CAS是什么
java·开发语言·c++
河西石头13 分钟前
powerconfig告别繁琐配置读写---为C#提供了一个快捷的读写配置文件的API
开发语言·c#·高效读写配置文件·c#配置文件·xml读写
IOT-Power16 分钟前
QT 事件驱动架构
开发语言·qt·架构
2401_8898846617 分钟前
模板代码模块化设计
开发语言·c++·算法
java1234_小锋17 分钟前
Java高频面试题:RabbitMQ中有哪几种交换机类型?
java·rabbitmq·java-rabbitmq
翘着二郎腿的程序猿21 分钟前
SpringBoot集成@Slf4j注解:优雅输出日志,告别手动new Logger
java·spring boot·intellij-idea