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

集合体系概述

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

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-原理

在这里插入图片描述

Java 2集合框架图  集合接口:6个接口(短虚线表示),表示不同集合类型,是集合框架的基础。  抽象类:5个抽象类(长虚线表示),对集合接口的部分实现。可扩展为自定义集合类。  实现类:8个实现类(实线表示),对接口的具体实现。  在很大程度上,一旦您理解了接口,您就理解了框架。虽然您总要创建接口特定的实现,但访问实际集合的方法应该限制在接口方法的使用上;因此,允许您更改基本的数据结构而不必改变其它代码。  · Collection 接口是一组允许重复的对象。  · Set 接口继承 Collection,但不允许重复,使用自己内部的一个排列机制。  · List 接口继承 Collection,允许重复,以元素安插的次序来放置元素,不会重新排列。  · Map接口是一组成对的键-值对象,即所持有的是key-value pairs。Map中不能有重复的key。拥有自己的内部排列机制。  · 容器中的元素类型都为Object。从容器取得元素时,必须把它转换成原来的类型。  Java 2简化集合框架图  集合接口  1.Collection 接口  用于表示任何对象或元素组。想要尽可能以常规方式处理一组元素时,就使用这一接口。  (1) 单元素添加、删除操作:   boolean add(Object o):将对象添加给集合   boolean remove(Object o): 如果集合中有与o相匹配的对象,则删除对象o  (2) 查询操作:   int size() :返回当前集合中元素的数量   boolean isEmpty() :判断集合中是否有任何元素   boolean contains(Object o) :查找集合中是否含有对象o
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值