Java的HashMap是<K,V>键值对结构存储数据。Java在遍历HashMap时候,有时候开发者可能不需要关心Key键或者开发者根本就不知道Key键是什么,就想获取value值或对value值做修改。那就可以使用Java的Map.Entry实现。
假设现在一个HashMap里面存放了三对值:<123,1> , <456,2> , <789,3>。开发者不想知道也可能不会知道key键值,只是希望在HashMap里面存储的value值:
如果是1,就换成3;
如果是2,就换成4;
如果是3,就换成5。
这种情况没必要根据key取value值,然后做替换,此时只需要把value遍历处理然后替换即可,例如:
private void test() {
HashMap<Object, Integer> map = new HashMap();
map.put(123, 1);
map.put(456, 2);
map.put(789, 3);
Set<Map.Entry<Object, Integer>> sets = map.entrySet();
Iterator<Map.Entry<Object, Integer>> iterator = sets.iterator();
while (iterator.hasNext()) {
Map.Entry<Object, Integer> entry = iterator.next();
//不关心key。
//Object key = entry.getKey();
Integer integer = entry.getValue();
if (integer == 1) {
entry.setValue(4);
}
if (integer == 2) {
entry.setValue(5);
}
if (integer == 3) {
entry.setValue(6);
}
}
System.out.println(map.get(123) + "");
System.out.println(map.get(456) + "");
System.out.println(map.get(789) + "");
}
输出:
2018-12-14 19:47:03.131 24838-24838/zhangphil.book I/System.out: 4
2018-12-14 19:47:03.131 24838-24838/zhangphil.book I/System.out: 5
2018-12-14 19:47:03.131 24838-24838/zhangphil.book I/System.out: 6