在HashMap中进行CaseInsensitive搜索

时间:2015-10-06 05:56:05

标签: java dictionary hashmap hashcode case-insensitive

我有一张地图:

static Map<String, String> = getMap(); //getting a map from a config file.

现在在这个Map中我需要使用KEYS执行caseInsensitive搜索。我不是将值放在map中,而不是通过put函数,但您可以将其视为以键值格式存储在数据库中的值,并将其作为Map检索。我需要做一个caseInsentive搜索。

经过研究,使用TreeMap可以解决问题,但效率不高 - &gt; O(log n)

或覆盖HashMap的get()方法,创建自己的HashMap。但这包括覆盖许多方法,我不想要这么多,它不是非常重要的代码的一部分。

现在我正在以数据库中的小写形式存储值并进行检查。但它使它在数据库中容易出错,而且不易读。

有没有更简单的方法呢?

2 个答案:

答案 0 :(得分:3)

1。)TreeMap扩展Map可以是一个选项,但时间复杂度为O(log n)

final Map<String, Object> map = new TreeMap<String, Object>(String.CASE_INSENSITIVE_ORDER);

2。)您可以使用上面建议的Apache的Commons Collections中的CaseInsensitiveMap

3。)创建自己的HashMap类和重写方法。

public class MyCaseInsensitiveMap extends HashMap<String, String> {
    ...
    put(String key, String value) {
       super.put(key.toLowerCase(), value);
    }

    get(String key) {
       super.get(key.toLowercase());
    }
}

4.。)您需要一个String键的包装类,它具有不区分大小写的equals()hashCode()实现。使用它代替地图键的字符串。

示例here

**除了apache commons之外,似乎没有可用的直接库。

PS:与SO中提供的其他链接合并。

答案 1 :(得分:0)

如果您对O(1)没问题,但利用更多空间,这可能会有所帮助:

class CaseInsensitiveLookupMap {

private Map<String,String> keysMap = new HashMap<String,String>();
private Map<String,String> dataMap;

public CaseInsensitiveLookupMap(Map<String,String> dataMap){
  this.dataMap=dataMap;
  for(String key: dataMap.keySet()){
     keysMap.put(key.toLowerCase(),key);
  }
}

public String get(String keyToSearch){
  String _key = keysMap.get(keyToSearch.toLowerCase());
  if(_key!=null) {
    return dataMap.get(_key);
  }
  return null;
}

}