Java将map置空_Java实现过滤掉map集合中key或value为空的值示例

Java实现过滤掉map集合中key或value为空的值示例

发布时间:2020-09-16 23:26:14

来源:脚本之家

阅读:147

作者:May的博客

本文实例讲述了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程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值