Java entrySet之Map.Entry

Java的HashMap是键值对结构存储数据。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 map = new HashMap();
        map.put(123, 1);
        map.put(456, 2);
        map.put(789, 3);

        Set> sets = map.entrySet();

        Iterator> iterator = sets.iterator();
        while (iterator.hasNext()) {
            Map.Entry 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

 

你可能感兴趣的:(Java)