5

キーが大文字と小文字を区別しないマルチ マップが必要です。Googleコレクションにそのような実装はありますか?

4

4 に答える 4

9

大文字と小文字を区別しないバージョンの a を次に示しますForwardingMap

public class CaseInsensitiveForwardingMap<V> extends ForwardingMap<String, V>
    implements Serializable{

    private static final long serialVersionUID = -7741335486707072323L;

    // default constructor
    public CaseInsensitiveForwardingMap(){
        this(new HashMap<String, V>());
    }

    // constructor with a supplied map    
    public CaseInsensitiveForwardingMap(final Map<String, V> inner){
        this.inner = inner;
    }

    private final Map<String, V> inner;
    @Override
    protected Map<String, V> delegate(){
        return inner;
    }

    // convert keys to lower case Strings, preserve null keys
    private static String lower(final Object key){
        return key == null ? null : key.toString().toLowerCase();
    }

    @Override
    public V get(final Object key){ return inner.get(lower(key)); }
    @Override
    public void putAll(final Map<? extends String, ? extends V> map){
        if(map == null || map.isEmpty()){  inner.putAll(map); }
        else{
            for(final Entry<? extends String, ? extends V> entry :
                map.entrySet()){
                    inner.put(lower(entry.getKey()), entry.getValue());
            }
        }
    }
    @Override
    public V remove(final Object object){ return inner.remove(lower(object)); }
    @Override
    public boolean containsKey(final Object key){
        return inner.containsKey(lower(key));
    }
    @Override
    public V put(final String key, final V value){
        return inner.put(lower(key), value);
    }
}

このマップをMultiMap使用すると、 のサプライヤ メソッドを使用して を作成できますMultiMaps

例:

Map<String, Collection<String>> map = 
    new CaseInsensitiveForwardingMap<Collection<String>>();
Multimap<String, String> caseInsensitiveMultiMap = 
    Multimaps.newMultimap(map, new Supplier<Collection<String>>(){

      @Override
      public Collection<String> get(){ return Sets.newHashSet(); }

  });

警告:keySet()キーの入力方法に関係なく、小文字の値のみが返されます。

于 2011-01-04T10:50:29.263 に答える
5

a を使用して、大文字と小文字を区別しない比較を行う aMap<String,List<Payload>>を与えることはできませんか?Comparator<String>

Google Collections も Apache Collection フレームワークも、キーの等価性を評価するための Comparator を受け入れる multimap を持っていないようです。

于 2011-01-04T10:48:17.290 に答える
3

Collat​​orを使用して、大文字と小文字を区別しない String Comparator を定義できます。次に、その Comparator によってソートされたキーで TreeMultimap を作成します。

于 2011-01-12T04:11:11.777 に答える
1

いいえ、でもおそらく文字列キーを使用していますか?もしそうなら、なぜ通常のマルチマップへのすべてのアクセスを正規化しないのですか?80%の場合、すべての呼び出しでキーが小文字になります。

大文字と小文字を区別しないマルチマップの問題の詳細については、このGoogleグループのディスカッションを参照してください。

于 2011-01-04T10:42:49.730 に答える