Map 和 Set 学习

        在 JavaScript 中,Map 和 Set 是 ES6 引入的两种新的数据结构,用于存储和管理数据。

Map:

  • Map 是一种键值对的集合,其中每个键和值之间存在映射关系。
  • 键可以是任意数据类型,包括对象、函数、原始类型等。
  • Map 中的键是唯一的,如果重复设置相同的键,则后面的值会覆盖前面的值。
  • 可以通过 set(key, value) 方法添加键值对,通过 get(key) 方法获取键对应的值,通过 delete(key) 方法删除键值对。
  • Map 是有序的,键值对的顺序与插入顺序一致。
  • 可以通过 size 属性获取 Map 中键值对的数量。
// 示例
let myMap = new Map();
myMap.set('name', 'Alice');
myMap.set('age', 30);

console.log(myMap.get('name')); // 输出 'Alice'
console.log(myMap.size); // 输出 2

Set:

  • Set 是一种值的集合,其中每个值都是唯一的,不允许重复。
  • 可以存储任意数据类型的值,包括对象、函数、原始类型等。
  • 可以通过 add(value) 方法向 Set 中添加值,通过 delete(value) 方法删除值,通过 has(value) 方法检查值是否存在。
  • Set 中的值是无序的,没有索引,不能通过索引访问值。
  • 可以通过 size 属性获取 Set 中值的数量。
    // 示例
    let mySet = new Set();
    mySet.add(1);
    mySet.add(2);
    mySet.add(1); // 重复值不会被添加
    
    console.log(mySet.has(1)); // 输出 true
    console.log(mySet.size); // 输出 2
    

 Map 的应用场景:

  1. 存储对象的键值对Map 可以用来存储对象的键值对,比如存储用户信息等。
    let userMap = new Map();
    userMap.set('name', 'Alice');
    userMap.set('age', 30);
    console.log(userMap.get('name')); // 输出 'Alice'
    
  2. 缓存数据Map 可以用来实现简单的缓存机制,存储计算结果以提高性能。
    let cacheMap = new Map();
    function calculateSquare(num) {
        if (cacheMap.has(num)) {
            return cacheMap.get(num);
        } else {
            const result = num * num;
            cacheMap.set(num, result);
            return result;
        }
    }
    console.log(calculateSquare(5)); // 第一次计算并缓存结果
    console.log(calculateSquare(5)); // 直接从缓存中获取结果
    

 Set 的应用场景:

  1. 去重数组Set 可以用来去除数组中的重复元素。
    let uniqueSet = new Set([1, 2, 3, 2, 1]);
    console.log([...uniqueSet]); // 输出 [1, 2, 3]
    
  2. 管理用户权限Set 可以用来存储用户的权限信息,判断用户是否有特定权限。
    let userPermissions = new Set(['read', 'write']);
    function hasPermission(permission) {
        return userPermissions.has(permission);
    }
    console.log(hasPermission('read')); // 输出 true
    console.log(hasPermission('delete')); // 输出 false
    
  3. 事件订阅与发布Set 可以用来管理订阅者,实现简单的事件订阅与发布机制。
    let subscribers = new Set();
    function subscribe(callback) {
        subscribers.add(callback);
    }
    function publish(data) {
        subscribers.forEach(callback => callback(data));
    }
    subscribe(data => console.log('Data received:', data));
    publish('Hello, world!');
    
  • 56
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Stream流遍历Map集合,可以通过调用Map接口的entrySet()方法获取一个Set集合,然后使用Stream流的forEach()方法来遍历这个Set集合。在forEach()方法中,可以使用Lambda表达式来对每个Entry进行操作。以下是一个示例代码: ``` Map<String, Integer> map = new HashMap<>(); map.put("a", 1); map.put("b", 2); map.put("c", 3); map.entrySet().stream().forEach(entry -> { String key = entry.getKey(); Integer value = entry.getValue(); System.out.println("Key: " + key + ", Value: " + value); }); ``` 在这个示例中,我们首先创建了一个包含键值对的Map集合。然后,通过调用entrySet()方法获取一个Set集合,再通过stream()方法将这个Set集合转换为一个Stream流。接下来,使用forEach()方法来遍历这个Stream流,对每个Entry进行操作。在Lambda表达式中,我们可以通过entry.getKey()和entry.getValue()方法分别获取键和值,并将它们打印出来。 这样,就可以使用Stream流遍历Map集合了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Stream流的方式遍历map,筛选数据](https://blog.csdn.net/qq_44716086/article/details/126332094)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Java学习与复习笔记--Stream流思想概述:](https://blog.csdn.net/gkx826/article/details/108543430)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [怎么在java 8的map中使用stream](https://download.csdn.net/download/weixin_38719719/14853217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值