Java集合中Map接口的使用方法
Map接口
- Map提供了一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value;
- Map中的键值对以Entry类型的对象实例形式存在;
- 建(key值)不可重复,value值可以重复,一个value值可以和很多key值形成对应关系,每个建最多只能映射到一个值。
- Map支持泛型,形式如:Map<K,V>
- Map中使用put(K key,V value)方法添加
HashMap类
- HashMap是Map的一个重要实现类,也是最常用的,基于哈希表实现
- HashMap中的Entry对象是无序排列的
- Key值和value值都可以为null,但是一个HashMap只能有一个key值为null的映射(key值不可重复)
下面我们以添加学生对象的实例演示Map的用法。
首先,创建一个学生类
import java.util.HashSet;
import java.util.Set; /**
* 学生类
* @author lenovo
*
*/
public class Student { public String id; public String name; public Set<KeCheng> kecheng; public Student(String id,String name){
this.id = id;
this.name = name;
this.kecheng = new HashSet<KeCheng>();
} }
然后再创建一个MapTest的测试类,演示Map的使用方法,并且创建一个演示put()方法和keySet()方法的成员方法
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.Set; public class MapTest { //创建一个Map属性用来承装学生对象
public Map<String,Student> student; /*
* 在构造器中初始化学生属性
*/
public MapTest(){
this.student = new HashMap<String,Student>();
} /*
* 添加方法:输入学生ID,判断是否被占用,
* 如果未被占用,则输入姓名,创建新学生对象,添加到student中
*/
public void testPut(){
//创建一个Scanner对象,输入学生ID
Scanner sc = new Scanner(System.in);
int i = 0;
while(i<3){
System.out.println("请输入学生ID:");
String stuID = sc.next();
Student stu = student.get(stuID);
if(stu == null){
System.out.println("请输入学生姓名:");
String stuName = sc.next();
Student newStudent = new Student(stuID,stuName);
student.put(stuID, newStudent);
System.out.println("成功添加学生:"+student.get(stuID).name);
i++;
}else{
System.out.println("该学生ID已被占用!");
continue;
} }
} /*
* 测试Map的keySet方法
*/
public void testKeySet(){
//通过keySet方法,返回Map中所有“键”的Set集合
Set<String> keySet = student.keySet();
//取得student的容量
System.out.println("总共有"+student.size()+"个学生;");
//遍历keySet,取得每一个键,再调用get方法取得每个键对应的value
for (String stuID : keySet) {
Student stu = student.get(stuID);
if(stu != null){
System.out.println("学生:"+stu.name);
}
}
} public static void main(String[] args) { MapTest mt = new MapTest();
mt.testPut();
mt.testKeySet();
} }
运行main方法后的结果如下:
请输入学生ID: 请输入学生姓名:
Tom
成功添加学生:Tom
请输入学生ID: 请输入学生姓名:
Jack
成功添加学生:Jack
请输入学生ID: 请输入学生姓名:
Lily
成功添加学生:Lily
总共有3个学生;
学生:Tom
学生:Jack
学生:Lily
使用Map中的remove()方法删除Map中的映射
/*
* 删除Map中的映射
*/
public void testRemove(){
Scanner sc = new Scanner(System.in);
while(true){
System.out.println("请输入要删除的学生ID:");
String stuID = sc.next();
//判断输入的ID是否存在对应的学生对象
Student stu = student.get(stuID);
if(stu == null){
System.out.println("输入的学生ID不存在!");
continue;
}
student.remove(stuID);
System.out.println("成功删除学生"+stu.name);
break;
}
testEntrySet();
}
使用entrySet()方法遍历Map
/*
* 通过entrySet来遍历Map
*/
public void testEntrySet(){
//通过entrySet返回Map中所有的键值对
Set<Entry<String,Student>> entrySet = student.entrySet();
for(Entry<String,Student> entry:entrySet){
System.out.println("取得键:"+entry.getKey());
System.out.println("对应的值为:"+entry.getValue().name);
}
}
使用put()方法来修改Map中已存在的映射
/*
* 使用put方法修改Map中已有的映射
*/
public void testModify(){
System.out.println("请输入要修改的学生ID:");
Scanner sc = new Scanner(System.in);
while(true){
String id = sc.next();
Student stu = student.get(id);
if(stu == null){
System.out.println("ID不存在!");
continue;
}
System.out.println("当前学生是:"+stu.name);
System.out.println("请输入新的学生:");
String name = sc.next();
Student newStu = new Student(id,name);
student.put(id, newStu);
System.out.println("修改成功!");
break;
}
}
使用Map中的containsKey()和containsValue()方法来判断Map中是否存在键或值
/*
* 测试Map中是否存在某个key值或value值
*/
public void testContainsKey(){
System.out.println("请输入学生ID:");
Scanner sc = new Scanner(System.in);
String stuID = sc.next();
//用containsKey()方法来判断是否存在某个key值
System.out.println("输入的ID为:"+stuID+",在学生列表中是否存在:"+student.containsKey(stuID));
if(student.containsKey(stuID)){
System.out.println("学生的姓名为:"+student.get(stuID).name);
} System.out.println("请输入学生姓名:");
String name = sc.next();
//用containsValue()方法来判断是否存在某个value值
if(student.containsValue(new Student(null,name))){
System.out.println("存在学生"+name);
}else{
System.out.println("学生不存在");
}
}
使用containsKey()和containsValue()方法判断是,先在学生类里重写equals()和hashCode()方法,如果只判断值的话,equals方法里只重写和值相关的内容。
Java集合中Map接口的使用方法的更多相关文章
- Java集合框架Map接口
集合框架Map接口 Map接口: 键值对存储一组对象 key不能重复(唯一),value可以重复 常用具体实现类:HashMap.LinkedHashMap.TreeMap.Hashtable Has ...
- Java集合框架——Map接口
第三阶段 JAVA常见对象的学习 集合框架--Map集合 在实际需求中,我们常常会遇到这样的问题,在诸多的数据中,通过其编号来寻找某一些信息,从而进行查看或者修改,例如通过学号查询学生信息.今天我们所 ...
- JAVA集合框架 - Map接口
Map 接口大致说明(jdk11): 整体介绍: 一个将键映射到值的(key-value)对象, 键值(key)不能重复, 每个键值只能影射一个对象(一一对应). 这个接口取代了Dictionary类 ...
- Java集合之Map接口
Map使用键值对来存储数据,将键映射到值对象,一个映射不能包含重复的键,每一个键最多只能映射到一个值.Map接口的具体实现类:HashMap,Hashtable,TreeMap,LinkedHashM ...
- Java 集合之Collection 接口和遍历方法
这几篇是我按网上的教程来实习的. URL: http://www.cnblogs.com/jbelial/archive/2013/03/27/2981395.html 打代码的感觉挻好的.. 注意在 ...
- java 类中定义接口的调用方法
public class Human { public interface MyAction { public void getPower(); } } public class Test{ publ ...
- Java集合中的Map接口
jdk1.8.0_144 Map是Java三种集合中的一种位于java.util包中,Map作为一个接口存在定义了这种数据结构的一些基础操作,它的最终实现类有很多:HashMap.TreeMap.So ...
- Java集合中List,Set以及Map等集合体系详解
转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...
- java中map接口hashMap以及Enty之间的用法和关系
java中map接口hashMap以及Enty之间的转换 首先说的是map接口: Map提供了一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value ...
随机推荐
- Hello World(本博客启程篇)
Hello World 作为本博客第一篇日志,作为程序员,无论走到哪里,做什么事,必须先输出这句话. 一个想法 从今天3月份到现在一直在学技术,过程中坑的解决.知识的总结以及想法等都写到了" ...
- Jedis 例子(demo)大全
第一步:到git下载jedis源码,如果你用maven或者gradle,那么直接下官方的即可,地址:https://github.com/xetorthio/jedis:如果你用ant,下载这个:ht ...
- mapreduce 本地调试需要注意的问题
1.写好的程序直接在hadoop集群里面执行 2.如果需要在本地调试,需要注释掉mapred-site.xml <configuration> <!-- <property&g ...
- 使用DOS比较两个txt文件的差异
将两个文件放入到同一个文件夹下 DOS下提供了FC命令 点击开始->运行->输入cmd,进入DOS下,进入指定目录,输入FC a.txt b.txt进行比较,下面会显示出之间的差异
- 在Linux下和Windows下遍历目录的方法及如何达成一致性操作
最近因为测试目的需要遍历一个目录下面的所有文件进行操作,主要是读每个文件的内容,只要知道文件名就OK了.在Java中直接用File类就可以搞定,因为Java中使用了组合模式,使得客户端对单个文件和文件 ...
- Web前端开发规范文档(google规范)
(Xee:其实没什么规范约束,但是养成一种好习惯,何乐而不为?) 区分大小写 xhtml 区分大小写,xhtml要求 标签名 属性名 值都要小写,并且要有双引号和 标签闭合. css 元素名称以及i ...
- R语言 推荐算法 recommenderlab包
recommend li_volleyball 2016年3月20日 library(recommenderlab) library(ggplot2) # data(MovieLense) dim(M ...
- Javascript软键盘设计
国内大多数网站的密码在网络传输过程中都是明文的,我们目前正在做的产品也是这样的情形,这正常吗? 大家都偷懒?不重视安全?各人持有观点,有人认为明文传输并不是想象中的那么可怕,事实上正常情况下这些报文你 ...
- Ruby学习之module
我们可以认为module是一个专门存放一系列方法和常量的工具箱. module和class非常像, 只是module不能创建实例也不能有子类, 它们仅仅能存放东西. 例如: module Circle ...
- POJ 2486 Apple Tree
好抽象的树形DP......... Apple Tree Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6411 Accepte ...