org.seasar.framework.util.Maps Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2004-2015 the Seasar Foundation and the Others.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
package org.seasar.framework.util;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.IdentityHashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.TreeMap;
import java.util.WeakHashMap;
import java.util.concurrent.ConcurrentHashMap;
/**
* 簡潔な記述で{@link Map}のインスタンスを生成して値を設定するためのユーティリティクラスです。
*
* 本クラスをstatic importすることにより、次のようにMap
のインスタンスを簡潔に初期化することができます。
*
*
*
* Map<tring, Integer> map = map("a", 1).$("b", 2).$("c", 3).$();
*
*
* @author koichik
* @param
* Map
のキーの型
* @param
* Map
の値の型
* @since 2.4.18
*/
public class Maps {
/** 作成対象のMap
*/
protected Map map;
/**
* 指定されたキーと値を持つ{@link Map}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link Map}を構築するためのMaps
*/
public static Maps map(KEY key, VALUE value) {
return linkedHashMap(key, value);
}
/**
* 指定されたキーと値を持つ{@link ConcurrentHashMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link ConcurrentHashMap}を構築するためのMaps
*/
public static Maps concurrentHashMap(KEY key,
VALUE value) {
return new Maps(new ConcurrentHashMap()).$(key,
value);
}
/**
* 指定されたキーと値を持つ{@link HashMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link HashMap}を構築するためのMaps
*/
public static Maps hashMap(KEY key, VALUE value) {
return new Maps(new HashMap()).$(key, value);
}
/**
* 指定されたキーと値を持つ{@link Hashtable}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link Hashtable}を構築するためのMaps
*/
public static Maps hashtable(KEY key, VALUE value) {
return new Maps(new Hashtable()).$(key, value);
}
/**
* 指定されたキーと値を持つ{@link IdentityHashMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link IdentityHashMap}を構築するためのMaps
*/
public static Maps identityHashMap(KEY key,
VALUE value) {
return new Maps(new IdentityHashMap()).$(key,
value);
}
/**
* 指定されたキーと値を持つ{@link LinkedHashMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link LinkedHashMap}を構築するためのMaps
*/
public static Maps linkedHashMap(KEY key,
VALUE value) {
return new Maps(new LinkedHashMap()).$(key,
value);
}
/**
* 指定されたキーと値を持つ{@link TreeMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link TreeMap}を構築するためのMaps
*/
public static Maps treeMap(KEY key, VALUE value) {
return new Maps(new TreeMap()).$(key, value);
}
/**
* 指定されたキーと値を持つ{@link WeakHashMap}を構築するためのMaps
を返します。
*
* @param
* Map
のキーの型
* @param
* Map
の値ーの型
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return 指定されたキーと値を持つ{@link WeakHashMap}を構築するためのMaps
*/
public static Maps weakHashMap(KEY key, VALUE value) {
return new Maps(new WeakHashMap())
.$(key, value);
}
/**
* インスタンスを構築します。
*
* @param map
* キーと値を追加する対象のMap
*/
protected Maps(Map map) {
this.map = map;
}
/**
* {@link Map}にキーと値を追加します。
*
* @param key
* Map
に追加されるキー
* @param value
* Map
に追加される値
* @return このインスタンス自身
*/
public Maps $(K key, V value) {
map.put(key, value);
return this;
}
/**
* Map
を返します。
*
* @return キーと値が追加されたMap
*/
public Map $() {
return map;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy