package com.peace.love.carpo_test.tool;import java.util.List;
import java.util.Map;
import java.util.Set;/*** <p>Can save multiple the value of the map.</p>* Created in 2021/2/20.** @author 一笑奈何;*/
public interface HongDou_MultiValueMap<K, V> {/*** 添加Key-Value。** @param key key.* @param value value.*/void add(K key, V value);/*** 添加Key-List<Value>。** @param key key.* @param values values.*/void add(K key, List<V> values);/*** 设置一个Key-Value,如果这个Key存在就被替换,不存在则被添加。** @param key key.* @param value values.*/void set(K key, V value);/*** 设置Key-List<Value>,如果这个Key存在就被替换,不存在则被添加。* @param key key.* @param values values.* @see #set(Object, Object)*/void set(K key, List<V> values);/*** 替换所有的Key-List<Value>。** @param values values.*/void set(Map<K, List<V>> values);/*** 移除某一个Key,对应的所有值也将被移除。** @param key key.* @return value.*/List<V> remove(K key);/*** 移除所有的值。* Remove all key-value.*/void clear();/*** 拿到Key的集合。* @return Set.*/Set<K> keySet();/*** 拿到所有的值的集合。** @return List.*/List<V> values();/*** 拿到某一个Key下的某一个值。** @param key key.* @param index index value.* @return The value.*/V getValue(K key, int index);/*** 拿到某一个Key的所有值。** @param key key.* @return values.*/List<V> getValues(K key);/*** 拿到MultiValueMap的大小.** @return size.*/int size();/*** 判断MultiValueMap是否为null.** @return True: empty, false: not empty.*/boolean isEmpty();/*** 判断MultiValueMap是否包含某个Key.** @param key key.* @return True: contain, false: none.*/boolean containsKey(K key);}
package com.peace.love.carpo_test.tool;import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;/*** Created in 2021/2/20.** @author 一笑奈何*/
public class HongDou_LinkedMultiValueMap<K, V> implements HongDou_MultiValueMap<K, V> {protected Map<K, List<V>> mSource = new TreeMap<K, List<V>>();// protected Map<K, List<V>> mSource = new LinkedHashMap<K, List<V>>();public HongDou_LinkedMultiValueMap() {}@Overridepublic void add(K key, V value) {if (key != null) {// 如果有这个Key就继续添加Value,没有就创建一个List并添加Valueif (!mSource.containsKey(key))mSource.put(key, new ArrayList<V>(2));mSource.get(key).add(value);}}@Overridepublic void add(K key, List<V> values) {// 便利添加进来的List的Value,调用上面的add(K, V)方法添加for (V value : values) {add(key, value);}}@Overridepublic void set(K key, V value) {// 移除这个Key,添加新的Key-ValuemSource.remove(key);add(key, value);}@Overridepublic void set(K key, List<V> values) {// 移除Key,添加List<V>mSource.remove(key);add(key, values);}@Overridepublic void set(Map<K, List<V>> map) {// 移除所有值,便利Map里的所有值添加进来mSource.clear();mSource.putAll(map);}@Overridepublic List<V> remove(K key) {return mSource.remove(key);}@Overridepublic void clear() {mSource.clear();}//返回所有key@Overridepublic Set<K> keySet() {return mSource.keySet();}@Overridepublic List<V> values() {// 创建一个临时List保存所有的ValueList<V> allValues = new ArrayList<V>();// 便利所有的Key的Value添加到临时ListSet<K> keySet = mSource.keySet();for (K key : keySet) {allValues.addAll(mSource.get(key));}return allValues;}@Overridepublic List<V> getValues(K key) {return mSource.get(key);}@Overridepublic V getValue(K key, int index) {List<V> values = mSource.get(key);if (values != null && index < values.size())return values.get(index);return null;}@Overridepublic int size() {return mSource.size();}@Overridepublic boolean isEmpty() {return mSource.isEmpty();}@Overridepublic boolean containsKey(K key) {return mSource.containsKey(key);}}