Java entrySet之Map.Entry
  TEZNKK3IfmPf 2023年11月14日 24 0

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

 

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月14日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   15天前   34   0   0 java
  TEZNKK3IfmPf   29天前   43   0   0 java
TEZNKK3IfmPf