Map,List,set集合推荐遍历的方式

Map,List,set集合推荐遍历的方式

import java.util.*;

/**
 * @Author 杨旭辉
 * @Date 2020/12/17 14:50
 * @Description Map,List,set集合推荐遍历的方式
 **/
public class Test {

    public static void main(String[] args) {

        /**
         * @Author YXH
         * @Date  2020/12/17 15:15
         * @Param [args]
         * @Return void
         * @Description map集合推荐遍历方式
         **/
        Map<String, Object> over = new HashMap<String, Object>(12);

        over.put("杨旭辉", 21);

        for (Map.Entry<String, Object> a : over.entrySet()) {

            String key = a.getKey();

            Object value = a.getValue();

            System.err.println("姓名:" + key + "  年龄:" + value);
        }


        /**
         * @Author YXH
         * @Date  2020/12/17 15:15
         * @Param [args]
         * @Return void
         * @Description  list集合推荐遍历方式
         **/
        List<String> list  = new ArrayList<>();

        list.add("杨旭辉");

        list.add("21");

        //增强for循环遍历
        for(String s : list){

            System.err.println(s+"   list集合增强for循环遍历");
        }

        //Iterator迭代器遍历
        Iterator<String> i = list.iterator();
        while (i.hasNext()) {
            String s = i.next();
            System.err.println(s+"   list集合Iterator迭代器遍历");
        }

        /**
         * @Author YXH
         * @Date  2020/12/17 15:15
         * @Param [args]
         * @Return void
         * @Description  set集合推荐遍历方式
         **/
        Set<String> set = new HashSet<>(6);

        set.add("杨旭辉");

        set.add("21");

        //迭代器遍历set集合
        Iterator<String> it = set.iterator();
        while (it.hasNext()) {
            String str = it.next();
            System.err.println(str);
        }


        //增强for循环遍历set集合
        for(String str:set) {

            System.err.println(str);
        }

    }
}

Set主要包含三种存放数据类型都变量,分别是HashSet,LinkedHashSet,TreeSet.打开HashSet源码可以看到一个很熟悉到对象

HashSet 如果在第一次调用的时候就是new HashMap();
在这里插入图片描述
LinkedHashSet:底层就不是链表加hash加什么集合,而是:LinkedHashMap。
符合LinkedHashMap所有属性和性质,有序,不可重复

在这里插入图片描述在这里插入图片描述

TreeSet同样也是以TreeMap作为存储结构,有序,不可重复。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要使用Stream流遍Map集合,可以通过调用Map接口的entrySet()方法获取一个Set集合,然后使用Stream流的forEach()方法来遍这个Set集合。在forEach()方法中,可以使用Lambda表达式来对每个Entry进行操作。以下是一个示例代码: ``` Map<String, Integer> map = new HashMap<>(); map.put("a", 1); map.put("b", 2); map.put("c", 3); map.entrySet().stream().forEach(entry -> { String key = entry.getKey(); Integer value = entry.getValue(); System.out.println("Key: " + key + ", Value: " + value); }); ``` 在这个示例中,我们首先创建了一个包含键值对的Map集合。然后,通过调用entrySet()方法获取一个Set集合,再通过stream()方法将这个Set集合转换为一个Stream流。接下来,使用forEach()方法来遍这个Stream流,对每个Entry进行操作。在Lambda表达式中,我们可以通过entry.getKey()和entry.getValue()方法分别获取键和值,并将它们打印出来。 这样,就可以使用Stream流遍Map集合了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Stream流的方式map,筛选数据](https://blog.csdn.net/qq_44716086/article/details/126332094)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Java学习与复习笔记--Stream流思想概述:](https://blog.csdn.net/gkx826/article/details/108543430)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [怎么在java 8的map中使用stream](https://download.csdn.net/download/weixin_38719719/14853217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值