Map 工具类

map 工具类

key 是否存在 

/**
     *
     * key是否存在
     * @param map
     * @param key
     * @param <K>
     * @param <V>
     * @return
     */
    public static <K, V> Boolean isExistsInMapByKey(Map<K, V> map, K key) {
        if (map == null || key == null) {
            return false;
        }
        return map.containsKey(key);
    }


    

 value 是否存在

/**
     * Value 是否存在
     * @param map
     * @param object
     * @param <K>
     * @param <V>
     * @return
     */
    public static <K, V> Boolean isExistsInMapByValue(Map<K, V> map, V object) {
        if (map == null || object == null) {
            return false;
        }
        for (K key : map.keySet()) {
            V value = map.get(key);
            if (value.equals(object)) {
                return true;
            }
        }
        return false;
    }

根据key 排序

import java.util.Comparator;
import java.util.Map;
import java.util.TreeMap;

/**
 * @Auther: lizhi
 * @Date: 2018/9/12 20:59
 * @Description: 根据map Key 升序降序排列
 */
public class MapSortUtil{

    public static <K, V> Map<K, V> sortMapAscByKey(Map<K, V> map) {
        if (map == null || map.isEmpty())
            return new TreeMap<>();
        Map<K,V> sortMap = new TreeMap(new MapKeyComparatorAsc());
        sortMap.putAll(map);
        return sortMap;
    }

    public static <K, V> Map<K, V> sortMapDescByKey(Map<K, V> map) {
        if (map == null || map.isEmpty())
            return new TreeMap<>();
        Map<K,V> sortMap = new TreeMap(new MapKeyComparatorDesc());
        sortMap.putAll(map);
        return sortMap;
    }

    static class MapKeyComparatorAsc implements Comparator{
        @Override
        public int compare(Object o1, Object o2) {
            int i = o1.toString().compareTo(o2.toString());
            return i;
        }
    }

    static class MapKeyComparatorDesc implements Comparator{
        @Override
        public int compare(Object o1, Object o2) {
            return o2.toString().compareTo(o1.toString());

        }
    }
}

一些其他方法

https://www.cnblogs.com/avivahe/p/5657070.html [转载]

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值