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

cn.hutool.core.map.multi.AbsCollValueMap Maven / Gradle / Ivy

Go to download

Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。

There is a newer version: 5.8.34
Show newest version
package cn.hutool.core.map.multi;

import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.map.MapWrapper;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;

/**
 * 值作为集合的Map实现,通过调用putValue可以在相同key时加入多个值,多个值用集合表示
 *
 * @param  键类型
 * @param  值类型
 * @param  集合类型
 * @author looly
 * @since 5.7.4
 */
public abstract class AbsCollValueMap> extends MapWrapper {
	private static final long serialVersionUID = 1L;

	/**
	 * 默认集合初始大小
	 */
	protected static final int DEFAULT_COLLECTION_INITIAL_CAPACITY = 3;

	// ------------------------------------------------------------------------- Constructor start

	/**
	 * 构造
	 */
	public AbsCollValueMap() {
		this(DEFAULT_INITIAL_CAPACITY);
	}

	/**
	 * 构造
	 *
	 * @param initialCapacity 初始大小
	 */
	public AbsCollValueMap(int initialCapacity) {
		this(initialCapacity, DEFAULT_LOAD_FACTOR);
	}

	/**
	 * 构造
	 *
	 * @param m Map
	 */
	public AbsCollValueMap(Map m) {
		this(DEFAULT_LOAD_FACTOR, m);
	}

	/**
	 * 构造
	 *
	 * @param loadFactor 加载因子
	 * @param m          Map
	 */
	public AbsCollValueMap(float loadFactor, Map m) {
		this(m.size(), loadFactor);
		this.putAll(m);
	}

	/**
	 * 构造
	 *
	 * @param initialCapacity 初始大小
	 * @param loadFactor      加载因子
	 */
	public AbsCollValueMap(int initialCapacity, float loadFactor) {
		super(new HashMap<>(initialCapacity, loadFactor));
	}
	// ------------------------------------------------------------------------- Constructor end

	/**
	 * 放入所有value
	 *
	 * @param m valueMap
	 * @since 5.7.4
	 */
	public void putAllValues(Map> m) {
		if (null != m) {
			m.forEach((key, valueColl) -> {
				if (null != valueColl) {
					valueColl.forEach((value) -> putValue(key, value));
				}
			});
		}
	}

	/**
	 * 放入Value
* 如果键对应值列表有值,加入,否则创建一个新列表后加入 * * @param key 键 * @param value 值 */ public void putValue(K key, V value) { C collection = this.get(key); if (null == collection) { collection = createCollection(); this.put(key, collection); } collection.add(value); } /** * 获取值 * * @param key 键 * @param index 第几个值的索引,越界返回null * @return 值或null */ public V get(K key, int index) { final Collection collection = get(key); return CollUtil.get(collection, index); } /** * 移除value集合中的某个值 * * @param key 键 * @param value 集合中的某个值 * @return 是否删除成功 */ public boolean removeValue(K key, V value) { C collection = this.get(key); return null != collection && collection.remove(value); } /** * 移除value集合中的某些值 * * @param key 键 * @param values 集合中的某些值 * @return 是否删除成功 */ public boolean removeValues(K key, Collection values) { C collection = this.get(key); return null != collection && collection.removeAll(values); } /** * 创建集合
* 此方法用于创建在putValue后追加值所在的集合,子类实现此方法创建不同类型的集合 * * @return {@link Collection} */ protected abstract C createCollection(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy