欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-19 13:07:10
本文实例讲述了java实现过滤掉map集合中key或value为空的值。分享给大家供大家参考,具体如下: import java.util.collection;...

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

上一篇:

下一篇: