本文实例讲述了Java实现过滤掉map集合中key或value为空的值。分享给大家供大家参考,具体如下:
import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; /** * 过滤掉map集合中key或value为空的值 * @author lmb * @date 2017-3-14 */ public class MapRemoveNullUtil { /** * 移除map中空key或者value空值 * @param map */ public static void removeNullEntry(Map map){ removeNullKey(map); removeNullValue(map); } /** * 移除map的空key * @param map * @return */ public static void removeNullKey(Map map){ Set set = map.keySet(); for (Iterator iterator = set.iterator(); iterator.hasNext();) { Object obj = (Object) iterator.next(); remove(obj, iterator); } } /** * 移除map中的value空值 * @param map * @return */ public static void removeNullValue(Map map){ Set set = map.keySet(); for (Iterator iterator = set.iterator(); iterator.hasNext();) { Object obj = (Object) iterator.next(); Object value =(Object)map.get(obj); remove(value, iterator); } } /** * 移除map中的空值 * * Iterator 是工作在一个独立的线程中,并且拥有一个 mutex 锁。 * Iterator 被创建之后会建立一个指向原来对象的单链索引表,当原来的对象数量发生变化时,这个索引表的内容不会同步改变, * 所以当索引指针往后移动的时候就找不到要迭代的对象,所以按照 fail-fast 原则 Iterator 会马上抛出 java.util.ConcurrentModificationException 异常。 * 所以 Iterator 在工作的时候是不允许被迭代的对象被改变的。 * 但你可以使用 Iterator 本身的方法 remove() 来删除对象, Iterator.remove() 方法会在删除当前迭代对象的同时维护索引的一致性。 * @param obj * @param iterator */ private static void remove(Object obj,Iterator iterator){ if(obj instanceof String){ String str = (String)obj; if(isEmpty(str)){ //过滤掉为null和""的值 主函数输出结果map:{2=BB, 1=AA, 5=CC, 8= } // if("".equals(str.trim())){ //过滤掉为null、""和" "的值 主函数输出结果map:{2=BB, 1=AA, 5=CC} iterator.remove(); } }else if(obj instanceof Collection){ Collection col = (Collection)obj; if(col==null||col.isEmpty()){ iterator.remove(); } }else if(obj instanceof Map){ Map temp = (Map)obj; if(temp==null||temp.isEmpty()){ iterator.remove(); } }else if(obj instanceof Object[]){ Object[] array =(Object[])obj; if(array==null||array.length<=0){ iterator.remove(); } }else{ if(obj==null){ iterator.remove(); } } } public static boolean isEmpty(Object obj){ return obj == null || obj.toString().length() == 0; } public static void main(String[] args) { Map map = new HashMap(); map.put(1, "AA"); map.put("2", "BB"); map.put("5", "CC"); map.put("6",null); map.put("7", ""); map.put("8", " "); System.out.println(map);//输出结果:{2=BB, 1=AA, 7=, 6=null, 5=CC, 8= } removeNullEntry(map); System.out.println(map); } }
运行结果:
{1=AA, 2=BB, 5=CC, 6=null, 7=, 8= }
{1=AA, 2=BB, 5=CC, 8= }
更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。