本文实例讲述了java实现过滤掉map集合中key或value为空的值。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
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程序设计有所帮助。
原文链接:https://blog.csdn.net/lmb55/article/details/64551373