JAVA集合框架Map特性及实例解析
一 Map特性:
1 Map提供一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value;
2 Map中键值对以Entry类型的对象实例形式存在;
3 键,即key不可重复,但是value值可以;
4 每个键最多只能映射一个值;
5 Map接口提供了分别返回key值集合、value值集合以及Entry(键值对)集合的方法;
6 Map支持泛型,形式如:Map<K,V>
二 HashMap类:
1 HashMap是Map的一个重要实现类,也是最常用的,基于哈希表实现;
2 HashMap中的Entry对象是无序排列的;
3 Key值和Value值都可以为null,但是HashMap中只能有一个Key值为null的映射(key值不可重复);
示例:
package com.collection;
import java.util.HashMap;
import java.util.Set;
import java.util.Scanner;
public class MapTest {
public HashMap<String,Student> students = new HashMap<String,Student>();
/*
* 新建学生到Map中
* */
public void addStudent(){
//先添加三个学生
Scanner console = new Scanner(System.in);
int i = 0;
while(i<3){
System.out.println("请输入学生ID:");
String id = console.next();
Student s = students.get(id);
if(s == null){
System.out.println("请输入学生姓名:");
String name = console.next();
Student student = new Student(Integer.parseInt(id),name);
students.put(id,student);
System.out.println("添加了学生:"+student.id+"-"+student.name);
i++;
}else{
System.out.println("该ID已经被占用");
continue;
}
}
}
/*
* 试用HashMap的keySet方法
*
* 顺便遍历Students
* */
public void forEachStudents(){
Set<String> ks = students.keySet();
System.out.println("共有学生数量"+students.size()+"个,具体如下:");
for(String key: ks){
Student student = students.get(key);
if( student != null){
System.out.println("学生ID:"+student.id+"-学生姓名:"+student.name);
}
}
}
public static void main(String[] args){
MapTest mt = new MapTest();
mt.addStudent();
mt.forEachStudents();
}
}
其中Student类如下:
package com.collection;
import java.util.HashSet;
import java.util.Set;
public class Student {
public int id;
public String name;
//set中添加某个对象无论添加多少次,最终只会保留一个该对象(的引用),并且,保留的是第一次添加的那个
public Set<Course> course = new HashSet<Course>();
public Student(int id, String name){
this.id = id;
this.name = name;
}
}
返回结果:
请输入学生ID:
请输入学生姓名:
刘备
添加了学生:1-刘备
请输入学生ID:
请输入学生姓名:
关羽
添加了学生:2-关羽
请输入学生ID:
请输入学生姓名:
张飞
添加了学生:3-张飞
共有学生数量3个,具体如下:
学生ID:1-学生姓名:刘备
学生ID:2-学生姓名:关羽
学生ID:3-学生姓名:张飞
以上是 JAVA集合框架Map特性及实例解析 的全部内容, 来源链接: utcz.com/z/312037.html