All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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