在Java中,Map
和 Set
是两种非常常用的集合类型,它们分别属于Java集合框架的一部分。以下是它们的介绍和用法:
Map (映射)
Map
是一个存储键值对(key-value pairs)的集合,它允许你通过键(key)快速查找对应的值(value)。Map
中的键不允许重复,每个键最多对应一个值。Map
的实现类有很多,包括 HashMap
、LinkedHashMap
、TreeMap
等。
常用操作:
put(key, value)
: 将指定的值与此映射中的指定键关联(可选操作)。get(key)
: 返回指定键所映射的值。remove(key)
: 从映射中移除键及其对应的值(如果存在这样的映射关系)。containsKey(key)
: 如果映射包含指定键的映射关系,则返回 true。keySet()
: 返回映射中包含的键的 Set 视图。values()
: 返回映射中包含的值的 Collection 视图。entrySet()
: 返回映射中包含的映射关系的 Set 视图。
示例代码:
Map<String, Integer> map = new HashMap<>();
map.put("One", 1);
map.put("Two", 2);
map.put("Three", 3);
System.out.println(map.get("Two")); // 输出 2
map.remove("One");
System.out.println(map.containsKey("One")); // 输出 false
Set (集合)
Set
是一个不包含重复元素的集合,它主要用于存储唯一的元素。Set
的实现类包括 HashSet
、LinkedHashSet
和 TreeSet
。
常用操作:
add(element)
: 将指定的元素添加到此集合中(如果尚未添加)。remove(element)
: 从集合中移除指定的元素(如果存在)。contains(element)
: 如果集合中包含指定的元素,则返回 true。size()
: 返回集合中的元素数。isEmpty()
: 如果集合中没有元素,则返回 true。clear()
: 从集合中移除所有元素。
示例代码:
Set<Integer> set = new HashSet<>();
set.add(1);
set.add(2);
set.add(3);
set.add(1); // 重复添加,不会有影响
System.out.println(set.size()); // 输出 3
System.out.println(set.contains(2)); // 输出 true
set.remove(3);
System.out.println(set.isEmpty()); // 输出 false
set.clear();
System.out.println(set.isEmpty()); // 输出 true
在使用 Map
和 Set
时,你需要根据实际需求选择合适的实现类。例如,如果你需要快速的查找速度,可以选择 HashMap
;如果你需要保持插入顺序,可以选择 LinkedHashMap
;如果你需要按键的自然顺序排序,可以选择 TreeMap
。对于 Set
,HashSet
提供了最快的访问速度,LinkedHashSet
保持了插入顺序,而 TreeSet
则按元素的自然顺序或自定义顺序排序