• containsKey


    containsKey(Object key) 方法的规范中写道:“当且仅当此映射包含针对满足 (key==null ? k==null : key.equals(k)) 的键 k 的映射关系时,返回 true”。不 应将此规范解释为:调用具有非空参数 key 的 Map.containsKey 将导致对任意的键 k 调用 key.equals(k)。实现可随意进行优化,以避免调用 equals
    
    使用例子:
    1. 调用 Map 的 get() 方法获取数据;
    2. 如果返回不为 null, 直接返回该数据;
    3. 如果返回为 null, 则生成数据, 或者从其他地方获取数据, 然后存放入 Map 中, 最后返回该数据.
    这里, 我们可以通过使用 Map 的containsKey() 方法来检测数据(value)是否存在, 如果key存在, 则表明已经获取过一次数据, 那么直接返回该 key 在 Map 中的值. 不管是否为 null 都直接返回; 如果 key 不存在, 则去生成或者获取数据, 并放入到 Map 中, 并返回该数据.
    这里使用 containsKey() 来检测可以应用于: 1. 从其他地方获取的数据可能为空, 并且不会有变化; 2. 获取数据比较耗时. 这个场景下, 使用该方法可以大大降低消耗, 特别是在同步情况下。
    
    package com.okdi.controller;
    import java.util.HashMap;
    import java.util.Map;
    public class Test {
        /**
        * @param args
        */
        public static void main(String[] args) {
            Map map=new HashMap();
            map.put("a","aaa");
            System.out.println(map.containsKey("a")); //输出true 如果这个map集合中有这个key就返回true
            System.out.println(map.containsKey("b")); //输出false 没有就返回false
        }
    }
  • 相关阅读:
    541. Reverse String II
    540. Single Element in a Sorted Array
    初识python
    openCV
    openCV
    win环境下安装配置openCV-4.3.0
    力扣Leetcode 198. 打家劫舍
    力扣Leetcode 680. 验证回文字符串 Ⅱ
    力扣Leetcode 560. 和为K的子数组
    华师2019软件专硕复试机试题最后一题G:找数
  • 原文地址:https://www.cnblogs.com/tszr/p/16257441.html
Copyright © 2020-2023  润新知