我有两个map的大致结构如下:
【idmap】
111 aaa
113 bbb
114 ccc
115 aaa
116 ddd
【shamap】:
1 aaa
2 bbb
3 ccc
4 ddd
需要得到的结果是:
1 aaa 111
2 bbb 113
3 ccc 114
1 aaa 115
4 ddd 116 这种的。
就是说,shamap里面存的是没有重复的,然后每个value都对应一个序列1,2,3.....
我需要做的其实就是将shamap里面的value的值的序号加到idmap里面,idmap里面相同value的序号是一样的。
我想的是在一个idmap的迭代里面再放入shamap的迭代,然后判断两个map的value是否相同再输出。但是结果总是不对
Iterator<String> it = idmap.keySet().iterator();
Iterator<String> it2 = shamap.keySet().iterator();
while(it.hasNext()) {
String count = null;
String key = it.next();
String value = idmap.get(key);
while(it2.hasNext()){
String col = it2.next();
String value2 = shamap.get(col);
if (value.equals(value2)){
count= col;
}
}
System.out.println(count+" "+value+" "+key);
}
结果却只显示第一个的。。不知道是哪里逻辑不对,该怎么改呢。
1 aaa 111
null bbb 112
null ccc 114
null aaa 115
null ddd 116
Iterator는 한 번만 반복할 수 있으므로 이를 수행하려면 Entryset을 사용하는 것이 좋습니다.
반복자는 한 번만 순회할 수 있으므로 내부 반복자는 매번 전체 맵을 순회할 수 없습니다. 간단한 수정은 샤맵 반복자를 얻는 코드 줄을 첫 번째 while에 넣는 것입니다.
PS: 샤맵의 키와 값이 일대일로 일치하는지 확인할 수 있다면 값에서 키를 쉽게 찾을 수 있는 구아바의 BiMap 사용을 고려할 수 있습니다. 이렇게 하면 루프의 두 레이어가 필요하지 않습니다. 중첩되고 효율성이 높아집니다.