hashMap hashSet hashtable遍历

本文深入探讨了Java中三种集合框架的遍历方式:HashMap, HashSet, 和 Hashtable。详细解释了如何使用三种不同的遍历方法获取键值对和元素,包括基于集合键和值的迭代器遍历以及基于映射和集合的遍历方法。通过对比这些方法的效率和适用场景,帮助开发者更好地理解和运用这些强大的数据结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static void main(String[] args)
    {
        // hashMap
        Map<String, Integer> map = new HashMap<String, Integer>();
        map.put("a", 0);
        map.put("b", 1);
        map.put("c", 2);
        System.out.println("hashMap遍历:");
        // 遍历1
        for (String str : map.keySet())
        {
            String key = str;
            int value = map.get(key);
            System.out.print("key:" + key + " value:" + value + " | ");
        }
        // 遍历2(效率高于1)
        System.out.println();
        for (Entry<String, Integer> entry : map.entrySet())
        {
            System.out.print("key:" + entry.getKey() + " value:" + entry.getValue() + " | ");
        }
        // 遍历3
        System.out.println();
        for (Iterator<Map.Entry<String, Integer>> iterator = map.entrySet().iterator(); iterator.hasNext();)
        {
            Map.Entry<String, Integer> entry = iterator.next();
            System.out.print("key:" + entry.getKey() + " value:" + entry.getValue() + " | ");
        }

        // hashSet
        Set<String> set = new HashSet<String>();
        set.add("a");
        set.add("b");
        set.add("c");
        System.out.println("\nhashSet遍历:");
        // 遍历1
        for (Iterator<String> iterator = set.iterator(); iterator.hasNext();)
        {
            System.out.print(iterator.next() + " | ");
        }
        // 遍历2
        System.out.println();
        for (String str : set)
        {
            System.out.print(str + " | ");
        }

        // Hashtable
        System.out.println("\nHashtable遍历:");
        Hashtable<String, Integer> hashtable = new Hashtable<String, Integer>();
        hashtable.put("d", 3);
        hashtable.put("e", 4);
        hashtable.put("f", 5);
        // 遍历1
        for (Iterator<String> iterator = hashtable.keySet().iterator(); iterator.hasNext();)
        {
            String key = (String) iterator.next();
            Integer value = hashtable.get(key);
            System.out.print("key:" + key + " value:" + value + " | ");
        }
        // 遍历key
        System.out.println();
        for (Enumeration<String> enumeration = hashtable.keys(); enumeration.hasMoreElements();)
        {
            System.out.print("key:" + enumeration.nextElement() + " | ");
        }
        // 遍历value
        System.out.println();
        for (Enumeration<Integer> enumeration = hashtable.elements(); enumeration.hasMoreElements();)
        {
            System.out.print("value:" + enumeration.nextElement() + " | ");
        }
    }


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值