zoukankan      html  css  js  c++  java
  • Java不区分大小写的CaseInsensitiveMap

    Java中对于键值对,我们习惯使用类HashMap,使用方式:Map<String, String> result=new HashMap<String,String>();

    但是这种使用的键Key是区分大小写的,也就是说Name和name会被视为不同的键Key。如果我们需要不区分大小写。那么就要使用类CaseInsensitiveMap。

    使用方式,首先引用jar包,pom.xml:

    <dependency>
        <groupId>commons-collections</groupId>
        <artifactId>commons-collections</artifactId>
        <version>3.2.2</version>
    </dependency>

    然后Java的示例代码如下:

    复制代码
    public static void main(String[] args) {
        //Map<String, String> result=new HashMap<String,String>();
        Map<String, String> result = new CaseInsensitiveMap();
        result.put("name", "zhangsan");
        result.put("Name", "lisi");
    
        System.out.println(result.get("name"));
        System.out.println(result.get("nAme"));        
    }
    复制代码

    输出的结果就是:

    lisi

    lisi

    非常简单,但是注意包名。

    //-----------------------------------------------------------------------
    /**
    * Overrides convertKey() from {@link AbstractHashedMap} to convert keys to
    * lower case.
    * <p>
    * Returns {@link AbstractHashedMap#NULL} if key is null.
    *
    * @param key the key convert
    * @return the converted key
    */
    protected Object convertKey(Object key) {
    if (key != null) {
    char[] chars = key.toString().toCharArray();
    for (int i = chars.length - 1; i >= 0; i--) {
    chars[i] = Character.toLowerCase(Character.toUpperCase(chars[i]));
    }
    return new String(chars);
    } else {
    return AbstractHashedMap.NULL;
    }
    }

  • 相关阅读:
    题解——[[SHOI2010]最小生成树]
    7.12周总结
    还有5个月就NOIP2019了,我干了什么
    【CQOI2018】破解D-H协议
    【SHOI2006】仙人掌
    【HNOI/AHOI2018】道路
    2019.11纪中集训 宋新波老师和曹天佑学长的勉励
    纪中集训2019.11.05
    【2019.10.25 OI-Killer的模拟赛】3.鸡数
    【华东师附国庆模拟赛】Day2 1.矩阵
  • 原文地址:https://www.cnblogs.com/shizhijie/p/10070973.html
Copyright © 2011-2022 走看看