List有序可重复,通过索引访问,典型实现有ArrayList和LinkedList;2. Set不允许重复元素,一般无序,常用实现有HashSet、LinkedHashSet和TreeSet;3. Map存储键值对,键不可重复,通过键查找值,常见实现有HashMap、LinkedHashMap和TreeMap。
在Java中,List、Set和Map是集合框架中最常用的三种接口,它们用途不同,特性也各不相同。理解它们的区别,关键在于掌握各自的存储方式、是否允许重复、是否有序以及典型实现类。
List 是一个有序集合,元素按插入顺序排列,可以通过索引访问。
例如:
java Listlist = new ArrayList<>(); list.add("A"); list.add("B"); list.add("A"); // 可以重复添加 System.out.println(list.get(0)); // 输出 "A"
Set 接口用于存储不重复的元素,不允许重复值。
例如:
java Setset = new HashSet<>(); set.add("A"); set.add("B"); set.add("A"); // 添加失败,不会报错,但不生效 System.out.println(set.size()); // 输出 2
Map 不是 Collection 的子接口,它存储的是键(key)和值(value)的映射关系。
例如:
java Mapmap = new HashMap<>(); map.put("Alice", 25); map.put("Bob", 30); map.put("Alice", 26); // 键重复,会覆盖之前的值 System.out.println(map.get("Alice")); // 输出 26
基本上就这些。List 关注顺序和索引,Set 关注唯一性,Map 关注键值查找。根据使用场景选择合适的集合类型,能提升代码的清晰度和性能。