Map和Set有什么区别?

1.是什么

MapSet 是 Java 集合框架中的两个不同接口,它们用于存储不同类型的数据,并具有不同的行为和用途。


Map 接口

  • 存储类型Map 接口用于存储键值对(key-value pairs),其中键是唯一的,而值可以重复。
  • 键值对:每个键值对都有一个键和一个值,键用于查找值。
  • 存储顺序Map 接口不保证元素的顺序,尽管一些实现类(如 TreeMap)会保持元素的排序。
  • 键和值 :键和值可以是任何对象,包括 null
  • 操作Map 接口提供了丰富的操作,如 put(添加键值对)、get(根据键获取值)、remove(根据键删除键值对)等。

Set 接口

  • 存储类型Set 接口用于存储一组元素,其中元素是唯一的,不允许重复。
  • 元素Set 接口中的元素可以是任何对象,包括 null
  • 存储顺序Set 接口不保证元素的顺序,尽管一些实现类(如 TreeSet)会保持元素的排序。
  • 操作Set 接口提供了基本的操作,如 add(添加元素)、remove(删除元素)、contains(检查元素是否存在)等。

区别

  1. 存储类型Map 存储键值对,而 Set 存储单一的元素。
  2. 键和值Map 中的键是唯一的,而值可以重复;Set 中的元素都是唯一的。
  3. 操作Map 提供了更多的操作,如 putget,而 Set 提供了基本的操作,如 addremove
  4. 顺序 :虽然 MapSet 接口都不保证元素的顺序,但某些实现类(如 TreeMapTreeSet)会保持元素的排序。

示例

假设我们有一个包含字符串的集合:

java 复制代码
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.TreeMap;
import java.util.TreeSet;

public class MapSetExample {
    public static void main(String[] args) {
        // Map 示例
        HashMap<String, Integer> hashMap = new HashMap<>();
        hashMap.put("Apple", 1);
        hashMap.put("Banana", 2);
        hashMap.put("Cherry", 3);

        // Set 示例
        HashSet<String> hashSet = new HashSet<>();
        hashSet.add("Apple");
        hashSet.add("Banana");
        hashSet.add("Cherry");

        LinkedHashMap<String, Integer> linkedHashMap = new LinkedHashMap<>();
        linkedHashMap.put("Apple", 1);
        linkedHashMap.put("Banana", 2);
        linkedHashMap.put("Cherry", 3);

        LinkedHashSet<String> linkedHashSet = new LinkedHashSet<>();
        linkedHashSet.add("Apple");
        linkedHashSet.add("Banana");
        linkedHashSet.add("Cherry");

        TreeMap<String, Integer> treeMap = new TreeMap<>();
        treeMap.put("Apple", 1);
        treeMap.put("Banana", 2);
        treeMap.put("Cherry", 3);

        TreeSet<String> treeSet = new TreeSet<>();
        treeSet.add("Apple");
        treeSet.add("Banana");
        treeSet.add("Cherry");
    }
}

在这个例子中,我们创建了不同类型的 MapSet 实例,并添加了一些元素。由于 MapSet 接口不保证元素的顺序,因此添加元素的顺序可能与打印顺序不同。

相关推荐
LYFlied17 分钟前
【每日算法】LeetCode 78. 子集
数据结构·算法·leetcode·面试·职场和发展
月明长歌21 分钟前
【码道初阶】【Leetcode606】二叉树转字符串:前序遍历 + 括号精简规则,一次递归搞定
java·数据结构·算法·leetcode·二叉树
子枫秋月22 分钟前
C++字符串操作与迭代器解析
数据结构·算法
原来是好奇心22 分钟前
深入Spring Boot源码(八):高级特性与扩展点深度解析
java·源码·springboot
(●—●)橘子……23 分钟前
记力扣1471.数组中的k个最强值 练习理解
数据结构·python·学习·算法·leetcode
oioihoii26 分钟前
C++共享内存小白入门指南
java·c++·算法
布茹 ei ai27 分钟前
QtWeatherApp - 简单天气预报软件(C++ Qt6)(附源码)
开发语言·c++·qt·开源·开源项目·天气预报
Wpa.wk29 分钟前
自动化测试 - 文件上传 和 弹窗处理
开发语言·javascript·自动化测试·经验分享·爬虫·python·selenium
LinHenrY122730 分钟前
初识C语言(编译和链接)
c语言·开发语言·蓝桥杯
_OP_CHEN30 分钟前
【Python基础】(二)从 0 到 1 入门 Python 语法基础:从表达式到运算符的全面指南
开发语言·python