Java中Map和Set的用法及介绍

本文详细介绍了Java中的Map和Set集合类型,包括它们的定义、常用操作以及不同实现类的特点。通过示例代码展示了如何在实际项目中使用这些集合。
摘要由CSDN通过智能技术生成

在Java中,MapSet 是两种非常常用的集合类型,它们分别属于Java集合框架的一部分。以下是它们的介绍和用法:

Map (映射)

Map 是一个存储键值对(key-value pairs)的集合,它允许你通过键(key)快速查找对应的值(value)。Map 中的键不允许重复,每个键最多对应一个值。Map 的实现类有很多,包括 HashMapLinkedHashMapTreeMap 等。

常用操作:

  • 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 的实现类包括 HashSetLinkedHashSetTreeSet

常用操作:

  • 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

在使用 MapSet 时,你需要根据实际需求选择合适的实现类。例如,如果你需要快速的查找速度,可以选择 HashMap;如果你需要保持插入顺序,可以选择 LinkedHashMap;如果你需要按键的自然顺序排序,可以选择 TreeMap。对于 SetHashSet 提供了最快的访问速度,LinkedHashSet 保持了插入顺序,而 TreeSet 则按元素的自然顺序或自定义顺序排序

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

念君思宁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值