Java集合之Map与HashMap,另含Iterator的使用

Java集合之HashMap

(一)HashMap的简要特点

  • HashMap是最常用的Map,用于存储键值对。
  • 键不可以重复,值可以重复。所以HashMap最多只允许一条记录的键为Null,允许多条记录的值为Null。
  • HashMap是无序的,遍历时取得数据的顺序是完全随机的。
  • HashMap是非同步的,线程不安全的。

(二)Map的遍历

Map集合中是没有迭代器Iterator的,而Set具备迭代器Iterator
所以Map集合取出键值的原理是:先将Map集合中取出的结果存储为Set集合,然后再通过Set集合迭代器取出。

Map的遍历有两种方法,一种是keySet(),一种是entrySet()。下面我们以HashMap为栗子讲解这两种遍历的原理与使用。

1,keySet()遍历

keySet()用于取出Map中的所有键,然后Map.get(key)在Map集合中查找出这个键对应的值。

1)代码栗子

    public static void keySetExample(){
        Map<String,String>  hashMap = new HashMap<String,String>();
        hashMap.put("No","006");
        hashMap.put("Age","26");
        hashMap.put("Name","码奴");
        hashMap.put("Introduction","码奴从来只知道前进");
        // 先keySet()取出Map集合的所有键并转成Set集合
        Set<String> keys = hashMap.keySet();
        // 获取Set集合的迭代器it
        Iterator<String> it = keys.iterator();
        // 通过迭代器遍历Set集合的每一个元素,也就是存入的键key
        while(it.hasNext()){
            String key = it.next();
            //有了键,就可以通过map集合的get方法获取对应的值
            String value = hashMap.get(key);
            System.out.println(key + "  :  " + value);
        }
    }

2)输出结果

No  :  006
Introduction  :  码奴从来只知道前进
Age  :  26
Name  :  码奴

输出结果与hashMap.put()的键顺序是不一样的,因为HashMap.keySet()方法返回的Set数据是乱序排放的。

2,entrySet()遍历

entrySet()用于取出Map中的所有键值对,然后每个键值对通过getKey()获取自己的键,通过getValue()获取自己的值。

hashMap.entrySet();是将hashMap里的每一个键值对取出来封装成一个Entry对象在存到一个Set里面。
Map.Entry<String, String>的意思是一个泛型,表示Entry里装的是两个String类型的字符串,分别是key和value。Map.Entry是一个接口,该接口中的getKey()和getValue()方法可以方便我们取出键和值。

1)代码栗子

    public static void entrySetExample(){
        Map<String,String>  hashMap = new HashMap<String,String>();
        hashMap.put("No","005");
        hashMap.put("Age","25");
        hashMap.put("Name","码奴");
        hashMap.put("Introduction","码奴从来只知道前进");

        // 先entrySet()取出Map集合的所有键值对并存入Set集合
        Set< Map.Entry<String,String> > entrySet = hashMap.entrySet();
        // 获取Set集合的迭代器it
        Iterator< Map.Entry<String,String> > it = entrySet.iterator();
        // 通过迭代器遍历Set集合的每一个元素,也就是存入的键值对
        while(it.hasNext()){
            Map.Entry<String, String> mey = it.next();
            //getKey()和getValue是接口Map.Entry<K,V>中的方法,getKey()返回对应的键,getValue返回对应的值
            String key = mey.getKey();
            String value = mey.getValue();
            System.out.println(key + "  :  " + value);
        }
    }

2)输出结果

No  :  005
Introduction  :  码奴从来只知道前进
Age  :  25
Name  :  码奴

(三)Map遍历方式的抉择

在Set集合的迭代器遍历时,keySet()得到所有的键,然后hashMap.get(key)去查询出hashMap中该键对应的值。

在Set集合的迭代器遍历时,entrySet()得到所有的键值对,然后getKey()取出键,getValue()取出值。

由于hashMap.get(key)的环节,也就是得到键之后我们还要去查询出hashMap中该键对应的值,这个查询本身就是遍历hashMap直到得到该键对应的值。
entrySet()直接就得到了所需的键值对,无需遍历hashMap去获取值,直接可以访问自己的键和值。

所以推荐使用entrySet()方法,因为少了一个遍历hashMap直到获取键对应值的环节,效率较高。

(四)更常用的写法

1,keySet()的常用写法

        // 先keySet()取出Map集合的所有键并转成Set集合
        Set<String> keys = hashMap.keySet();
        // 获取Set集合的迭代器it
        Iterator<String> it = keys.iterator();

写成

        Iterator<String> it = hashMap.keySet().iterator();

2,entrySet()的常用写法

        // 先entrySet()取出Map集合的所有键值对并存入Set集合
        Set< Map.Entry<String,String> > entrySet = hashMap.entrySet();
        // 获取Set集合的迭代器it
        Iterator< Map.Entry<String,String> > it = entrySet.iterator();

写成

        Iterator< Map.Entry<String,String> > it = hashMap.entrySet().iterator();

(五)完整代码

package com.write;

import java.util.*;

public class RegexUtil {

    public static void keySetExample(){
        Map<String,String>  hashMap = new HashMap<String,String>();
        hashMap.put("No","006");
        hashMap.put("Age","26");
        hashMap.put("Name","码奴");
        hashMap.put("Introduction","码奴从来只知道前进");
        // 先keySet()取出Map集合的所有键并转成Set集合
        Set<String> keys = hashMap.keySet();
        // 获取Set集合的迭代器it
        Iterator<String> it = keys.iterator();
        // 通过迭代器遍历Set集合的每一个元素,也就是存入的键key
        while(it.hasNext()){
            String key = it.next();
            //有了键,就可以通过map集合的get方法获取对应的值
            String value = hashMap.get(key);
            System.out.println(key + "  :  " + value);
        }
    }

    public static void entrySetExample(){
        Map<String,String>  hashMap = new HashMap<String,String>();
        hashMap.put("No","005");
        hashMap.put("Age","25");
        hashMap.put("Name","码奴");
        hashMap.put("Introduction","码奴从来只知道前进");

        // 先entrySet()取出Map集合的所有键值对并存入Set集合
        Set< Map.Entry<String,String> > entrySet = hashMap.entrySet();
        // 获取Set集合的迭代器it
        Iterator< Map.Entry<String,String> > it = entrySet.iterator();
        // 通过迭代器遍历Set集合的每一个元素,也就是存入的键值对
        while(it.hasNext()){
            Map.Entry<String, String> mey = it.next();
            //getKey()和getValue是接口Map.Entry<K,V>中的方法,getKey()返回对应的键,getValue()返回对应的值
            String key = mey.getKey();
            String value = mey.getValue();
            System.out.println(key + "  :  " + value);
        }
    }

    public static void main(String[] args){
//        keySetExample();
        entrySetExample();
    }

}

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet中。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其中计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法中作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet中; 3)把集合中的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合中添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合中的每个元素的位置与内容; 4)打印集合的大小,然后删除集合中的第3个元素,并显示删除元素的内容,然后再打印目前集合中第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合中添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合中的每个元素的键与值; 4)打印集合的大小,然后删除集合中的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合中的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值