Map接口:
- Map提供了一种映射关系,其中的元素就是以键值对(key-value)的形式存储的,能够实现根据key快速查找value
- Map中的键值对以Entry类型的对象实例形式存在
- 键(key值)不可重复,value值也可以
- 每个键最多只能映射到一个值
- Map接口提供了分别返回key值集合,value值集合以及Entry(键值对)集合的方法
- Map支持泛型,形式如:Map<k,v>
HashMap类
- HashMap是Map的一个重要的实现类,也是最常用的,基于哈希表实现
- HashMap中的Entry对象是无序排列的
- key值和value值都可以为null,但是一个HashMap只能有一个key值为null的映射(key值不可以重复)
例子:通过添加学生到学生库中,并显示学生信息
1.MapTest类
package com.collection; import java.util.HashMap; import java.util.Map; import java.util.Scanner; import java.util.Set; public class MapTest { /** * @param args */ //用来承装学生类型的对象 public Map<String,Student> students; //构造器中初始化students数属性 public MapTest(){ students = new HashMap<String,Student>(); } /** *测试添加:输入学生ID,判断是否被占用 *若未被占用,则输入学生姓名,创建学生对象,并且 *添加到students中 */ public void testPut(){ Scanner console = new Scanner(System.in); int i=0; while(i<3){ System.out.println("请输入学生ID"); String ID = console.next(); //判断学生ID是否已经存在 Student st = students.get(ID); if(st==null){ //提示输入学生姓名 System.out.println("请输入学生姓名"); String name = console.next(); //创建新的学生对象 Student newStudent = new Student(ID,name); //通过调用students的put方法,添加ID-学生映射 students.put(ID, newStudent); System.out.println("成功添加学生:"+students.get(ID).name); i++; }else{ System.out.println("该学生ID已被占用"); continue; } } } //测试Map的keySet方法 public void testKeySet(){ //通过keySet方法,返回Map中所有“键”的Set集合 Set<String> keyset = students.keySet(); //取得students容量 System.out.println("总共有:"+students.size()+"个学生"); //遍历keyset取得每一个键,再调用get方法,得到每个键对应得value值 for (String stuId : keyset) { Student st = students.get(stuId); if(st!=null){ System.out.println("学生信息:"+st.id+"_"+st.name); } } } public static void main(String[] args) { // TODO 自动生成的方法存根 MapTest mt = new MapTest(); mt.testPut(); mt.testKeySet(); } }
注:HashMap是无序的。所以每次运行显示学生信息的时候,可能都是不一样的