java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java集合List、Set、Map

Java三大最常用集合List、Set、Map用法详解

作者:苏涵.

在Java集合框架中,List、Set、Map是最核心的三大接口,它们分别对应线性表、集合、键值对映射三种数据结构,各自有独特的设计目标和适用场景,这篇文章主要介绍了Java三大最常用集合List、Set、Map用法的相关资料,需要的朋友可以参考下

前言

List、Set、Map 作为最基础也最常用的三种集合类型,各自有着鲜明的特性和适用场景。本文梳理清楚它们的区别、用法和最佳实践,在开发中选对集合、少走弯路。

一、集合的本质

Java 集合框架的核心目的是存储、管理和操作一组对象,相比数组,集合支持动态扩容、提供丰富的操作方法(增删改查、排序、筛选等),是处理批量数据的首选。

List、Set 属于集合接口的子接口,而 Map 是独立的顶级接口(存储键值对),三者的核心差异体现在元素是否有序、是否允许重复上:

集合类型核心特征是否允许重复元素是否有序核心实现类
List有序可重复插入有序(索引有序)ArrayList、LinkedList
Set无序不可重复无序(HashSet)/ 有序(TreeSet)HashSet、TreeSet、LinkedHashSet
Map键值对存储,键唯一值可重复、键不可无序(HashMap)/ 有序(TreeMap)HashMap、TreeMap、LinkedHashMap

二、特性 + 用法 + 场景

1. List:有序可重复的 “动态数组”

List 的核心是有序性(按插入顺序保存,可通过索引访问)和可重复性(允许元素重复),就像我们日常用的 “待办清单”,可以按顺序查看、修改指定位置的内容。

import java.util.ArrayList;
import java.util.List;

public class ListDemo {
    public static void main(String[] args) {
        // 推荐使用接口声明,实现类实例化(面向接口编程)
        List<String> fruitList = new ArrayList<>();
        
        // 1. 添加元素
        fruitList.add("苹果");
        fruitList.add("香蕉");
        fruitList.add("苹果"); // 允许重复添加
        
        // 2. 按索引访问元素
        System.out.println("索引1的元素:" + fruitList.get(1)); // 输出:香蕉
        
        // 3. 修改元素
        fruitList.set(0, "红苹果");
        
        // 4. 遍历元素
        for (String fruit : fruitList) {
            System.out.println(fruit); // 输出:红苹果、香蕉、苹果
        }
        
        // 5. 删除元素
        fruitList.remove(2); // 删除索引2的“苹果”
    }
}

常用实现类对比:

适用场景:

需要按顺序存取数据、允许重复元素、需通过索引快速访问的场景(如:订单列表、用户留言列表)。

2. Set:无序不可重复的 “无重复集合”

Set 的核心是不可重复性(元素唯一),默认无序(HashSet),就像我们的 “用户标签库”,不允许同一个标签重复出现。

核心用法示例:

import java.util.HashSet;
import java.util.Set;

public class SetDemo {
    public static void main(String[] args) {
        Set<String> tagSet = new HashSet<>();
        
        // 1. 添加元素
        tagSet.add("Java");
        tagSet.add("Spring");
        tagSet.add("Java"); // 重复元素,添加失败
        
        // 2. 遍历元素(无序)
        for (String tag : tagSet) {
            System.out.println(tag); // 输出:Java、Spring(顺序不固定)
        }
        
        // 3. 判断元素是否存在
        boolean hasJava = tagSet.contains("Java");
        System.out.println("是否包含Java标签:" + hasJava); // 输出:true
        
        // 4. 去重场景(核心价值)
        List<String> rawList = List.of("a", "b", "a", "c");
        Set<String> uniqueSet = new HashSet<>(rawList);
        System.out.println("去重后的集合:" + uniqueSet); // 输出:[a, b, c]
    }
}

常用实现类对比:

适用场景:

需要去重、无需按顺序存取数据的场景(如:用户标签、抽奖名单(避免重复中奖)、缓存的唯一键集合)。

3. Map:键值对存储的 “字典”

Map 的核心是键值对(Key-Value) 存储,键(Key)唯一、值(Value)可重复,就像我们的 “字典”—— 通过唯一的 “单词(Key)” 找到对应的 “释义(Value)”。

核心用法示例:

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class MapDemo {
    public static void main(String[] args) {
        Map<Integer, String> userMap = new HashMap<>();
        
        // 1. 添加键值对
        userMap.put(1, "张三");
        userMap.put(2, "李四");
        userMap.put(1, "张小三"); // 键重复,覆盖原有值
        
        // 2. 通过键获取值
        String userName = userMap.get(2);
        System.out.println("ID为2的用户:" + userName); // 输出:李四
        
        // 3. 遍历Map(三种方式)
        // 方式1:遍历所有键
        Set<Integer> keys = userMap.keySet();
        for (Integer key : keys) {
            System.out.println("键:" + key + ",值:" + userMap.get(key));
        }
        
        // 方式2:遍历所有键值对(推荐,效率高)
        for (Map.Entry<Integer, String> entry : userMap.entrySet()) {
            System.out.println("ID:" + entry.getKey() + ",姓名:" + entry.getValue());
        }
        
        // 方式3:遍历所有值(不关心键时)
        for (String value : userMap.values()) {
            System.out.println("姓名:" + value);
        }
        
        // 4. 判断键是否存在
        boolean hasKey1 = userMap.containsKey(1);
        System.out.println("是否包含键1:" + hasKey1); // 输出:true
    }
}

常用实现类对比:

适用场景:

需要通过唯一标识(键)快速查找对应数据的场景(如:用户 ID 映射用户信息、配置项存储、缓存数据)。

三、使用集合的核心注意事项

// 自定义User类示例(重写hashCode和equals)
class User {
    private Integer id;
    private String name;
    
    // 构造器、getter/setter省略
    
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User user = (User) o;
        return id.equals(user.id); // 按ID判断相等
    }
    
    @Override
    public int hashCode() {
        return id.hashCode(); // 基于ID生成哈希值
    }
}

总结 

到此这篇关于Java三大最常用集合List、Set、Map用法的文章就介绍到这了,更多相关Java集合List、Set、Map内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文