【开源项目】Android下自定义HASH【支持一个key对应多个value--根据key排序】
生活随笔
收集整理的這篇文章主要介紹了
【开源项目】Android下自定义HASH【支持一个key对应多个value--根据key排序】
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
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);/*** 設(shè)置一個Key-Value,如果這個Key存在就被替換,不存在則被添加。** @param key key.* @param value values.*/void set(K key, V value);/*** 設(shè)置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就繼續(xù)添加Value,沒有就創(chuàng)建一個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,調(diào)用上面的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() {// 創(chuàng)建一個臨時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);}}
?
總結(jié)
以上是生活随笔為你收集整理的【开源项目】Android下自定义HASH【支持一个key对应多个value--根据key排序】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 乐视2配置参数设置(乐视二参数配置)
- 下一篇: 金牛座男生喜欢一个人的表现(对你有好感3