浅入深出之Java集合框架(中)

时间:2021-10-06 20:31:11

Java中的集合框架(中)

由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,如果已经有java基础的小伙伴可以直接跳到浅入深出之Java集合框架(下).

目 录

浅入深出之Java集合框架(上)

浅入深出之Java集合框架(中)  

浅入深出之Java集合框架(下)

Java集合框架编程练习小程序——扑克牌小游戏

前 言

在<浅入深出之Java集合框架(上)>中介绍了List接口和Set接口的基本操作,在这篇文章中,我将介绍关于Map接口的基本操作。使用的示例是在<浅入深出之Java集合框架(上)>中的模拟学生选课的小程序,不清楚的朋友可以先去阅读<浅入深出之Java集合框架(上)>。

一、Map&HashMap简介

1)Map接口

浅入深出之Java集合框架(中)

1. Map接口提供了一中映射关系,其中的元素是键值对(key-value)的形式存储的,能够实现根据Key快速查找value。Key-value可以是任何对象,是以Entry类型的对象实例存在的。

2.Key是不可以重复的,Value是可以重复的。Key-value都可以为null,不过只能有一个key是null。

3.Map支持泛型,Map<K,V>

4.每个键最多只能映射到一个值

5.Map接口提供了分别返回key值集合、value值集合以及Entry(键值对)集合的方法

6.通过put<K key,V value>,remove<Object key>操作数

2)HashMap实现类

1.  HashMap中的Entry对象是无序排列的,HashMap是Map的一个重要实现类,也是最常用的,基于哈希表是实现

2.  Key值和value值都可以为null,但是一个HashMap只能有一个key值为null的映射(key不可重复)

二、学生选课——使用Map添加学生

案例功能说明

1.通过Map<String,Student>进行学生信息管理,其中key为学生ID,value为学生对象。

2.通过键盘输入学生信息

3.对集合中的学生信息进行增删该查操作

首先创建一个StuMap类来测试Map的使用方法。如下:

 /**
* 学生类的Map集合类
*
* @author acer
*
*/
public class StuMap {
// 用来承装学生类型对象
private Map<String, Student> students;
private static Scanner in;
{
in = new Scanner(System.in);
} public StuMap() {
students = new HashMap<String, Student>(); }
//省略方法,下面的方法会逐个列出
}

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

和List接口不同,向Map添加对象使用的是put(key,value)方法。以下是使用示例:

   /*
* 添加学生类 输入学生id,
* 判断是否被占用 若未被占用,则输入姓名,创建新的学生对象,并且把该对象添加到Map中
* 否则,则提示已有该id
*/
public void AddStu() {
System.out.println("请输入要添加的学生id:");
String Id = in.next();// 接受输入的id
Student st=students.get(Id);
if(st==null){ System.out.println("请输入要添加的学生姓名:");
String name = in.next();// 接受输入的name
this.students.put(Id, new Student(Id, name));
}else{
System.out.println("此Id已被占用!");
} }

再写一个打印输出的测试函数,如:

 /*
* 打印学生类
*
*/
public void PrintStu() {
System.out.println("总共有"+this.students.size()+"名学生:");
//遍历keySet
for (String s : this.students.keySet()) {
Student st=students.get(s);
if(st!=null){
System.out.println("学生:" + students.get(s).getId() + "," + students.get(s).getName());
}
}
}

上面的例子是使用Map的keySet()返回Map中的key的Set集合再用if进行判断输出,在Map还可以用entrySet()的方法返回Map中的键值对Entry,如:

 /*
* 通过entrySet方法遍历Map
*/
public void EntrySet(){
Set<Entry<String, Student>> entrySet =students.entrySet();
for(Entry<String, Student> entry:entrySet){
System.out.println("取得建:"+entry.getKey());
System.out.println("对应的值:"+entry.getValue().getName()); }
}

最后我们用主函数调用一下这些函数来看看效果如何

 public static void main(String[] args) {
StuMap stu = new StuMap();
for (int i = 0; i < 3; i++) {
stu.AddStu();
}
stu.PrintStu();
stu.EntrySet();
}

代码分析:

1.student.get(ID)是采用Map的get()方法,检测是否存在值为ID的学生,如果没有,则返回null。这里的案例是把Map中的key值设为学生的ID值,所以可以用这样的方式来检测,如果key值是学生其他属则性另当别论!!

2.keySet()方法,返回所有键的Set集合。

3.keyset()返回Map中所有的key以集合的形式可用Set集合接收,HashMap当中的映射是无序的。

3.Map还可以用entrySet()的方法返回Map中的键值对Entry,Entry也是Set集合,它可以调用getKey()和getValue()方法来分别得到键值对的“键”和“值”

运行结果:

浅入深出之Java集合框架(中)

三、学生选课——删除Map中的学生

删除Map中的键值对是调用remove(object key)方法,下面是它的使用示例:

 /*
* 删除map中映射
*/
public void RemoveStu(){
do{
System.out.println("请输入要删除的学生id:");
String Id = in.next();// 接受输入的id
Student st=students.get(Id);
if(st==null){
System.out.println("此id不存在!"); }else{
this.students.remove(Id);
System.out.println("成功删除"+st.getId()+","+st.getName()+"同学");
break;
}
}while(true);
}

运行结果:

浅入深出之Java集合框架(中)

四、学生选课——修改Map中的学生

修改Map中的键值对有两种方法,第一种就是用put方法。其实就是添加方法中的put,使用方法跟添加无异,这里的本质就是利用put把原来的数据给覆盖掉,即修改。

 /*
* 利用put方法修改Map中的value值
*/
public void ModifyStu(){
do{
System.out.println("请输入要修改的学生id:");
String Id = in.next();// 接受输入的id
Student st=students.get(Id);
if(st==null){
System.out.println("此id不存在!"); }else{
System.out.println("学生原来的姓名:"+st.getName()+",请输入修改后的姓名:");
String name = in.next();// 接受输入的name
st=new Student(Id,name);
this.students.put(Id,st);
System.out.println("成功修改!修改后的学生为:"+st.getId()+","+st.getName()+"同学");
break;
}
}while(true); }

除了用put方法外,Map中提供一个叫做replace的方法,知名知其意,就是“替换”的意思。replace的方法使用和put方法一样,这是因为它的内部源码如下:

 if (map.containsKey(key)) {
return map.put(key, value);
} else
return null;

可以看出replace方法就是调用put方法来完成修改操作的,但是我们为了和添加put进行区分,最好在使用修改的时候用replace方法进行修改。这样的代码可读性和维护性就增强了。

那么使用replace修改Map中的value值如下:(推荐使用replace方法)

 /*
* 利用replace方法修改Map中的value值
*/
public void Modify(){
do{
System.out.println("请输入要修改的学生id:");
String Id = in.next();// 接受输入的id
Student st=students.get(Id);
if(st==null){
System.out.println("此id不存在!"); }else{
System.out.println("学生原来的姓名:"+st.getName()+",请输入修改后的姓名:");
String name = in.next();// 接受输入的name
st=new Student(Id,name);
this.students.replace(Id, st);
System.out.println("成功修改!修改后的学生为:"+st.getId()+","+st.getName()+"同学");
break;
}
}while(true);
}

运行结果:

浅入深出之Java集合框架(中)

五、总结

Map -特点:元素成对出现,key-value,是映射关系,key不能重复,但value可以重复,也就是说,可以多key对一个value。支持泛型如Map<yy1, yy2>。

-实现类:HashMap是最常用的,HashMap中是无序排列,其元素中key或value可为null(但只能有一个为null)。

-声明(泛型)举例: 在类中声明 public Map<类型1, 类型2> xxx; 然后再构造方法中this.xxx = new HashMap<类型1, 类型2();

-获取:yy temp = xxx.get(key)

-添加:xxx.put( key(xx型), zz(yy型) );

-返回map中所有key(返回是set型集合形式) set xxxxx = xxx.keyset(); 用于遍历。

-返回map中所有entry对(key-value对)(返回是set型集合形式) set<Entry<xx, yy>> xxxxx = xxx.entrySet(); 同样用于遍历。 遍历时:for(Entry<xx,yy> 元素: xxxxx)

-删除:xxx.remove(key);

-修改:可以用put,当put方法传入的key存在就相当于是修改(覆盖);但是推荐使用replace方法!


本章主要介绍了Map接口的基本操作,发出下一篇预告:集合的基本操作不够用怎么办?如何判断集合中的某个元素对象是否存在?如何对List集合进行排序呢?这些问题是否困扰着你呢,在下一篇中博主将会针对这些问题来给大家介绍java集合框架的其他成员,后续如何请关注~~

浅入深出之Java集合框架(中)的更多相关文章

  1. 浅入深出之Java集合框架(上)

    Java中的集合框架(上) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,如果已经有java基础的小伙伴可以直接跳到<浅入深出之Java集合框架 ...

  2. 浅入深出之Java集合框架(下)

    Java中的集合框架(下) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,哈哈这篇其实也还是基础,惊不惊喜意不意外 ̄▽ ̄ 写文真的好累,懒得写了.. ...

  3. 浅入深出Vue:工具准备之PostMan安装配置及Mock服务配置

    浅入深出Vue之工具准备(二):PostMan安装配置 由于家中有事,文章没顾得上.在此说声抱歉,这是工具准备的最后一章. 接下来就是开始环境搭建了~尽情期待 工欲善其事必先利其器,让我们先做好准备工 ...

  4. 浅入深出Vue:前言

    浅入深出Vue系列文章 之前大部分是在做后端,后来出于某些原因开始接触Vue.深感前端变化之大,各种工具.框架令人眼花缭乱.不过正是这些变化,让前端开发更灵活. 博主在刚开始时,参考官网的各个步骤以及 ...

  5. 『浅入深出』MySQL 中事务的实现

    在关系型数据库中,事务的重要性不言而喻,只要对数据库稍有了解的人都知道事务具有 ACID 四个基本属性,而我们不知道的可能就是数据库是如何实现这四个属性的:在这篇文章中,我们将对事务的实现进行分析,尝 ...

  6. 浅入深出Vue:第一个页面

    今天正式开始入门篇,也就是实战了~ 首先我们是要做一个博客网站,UI 框架采用江湖传闻中的 ElementUI,今天我们就来利用它确定我们博客网站的基本布局吧. 准备工作 新建一个vue项目(可以参考 ...

  7. 浅入深出Vue:环境搭建

    浅入深出Vue:环境搭建 工欲善其事必先利其器,该搭建我们的环境了. 安装NPM 所有工具的下载地址都可以在导航篇中找到,这里我们下载的是最新版本的NodeJS Windows安装程序 下载下来后,直 ...

  8. 浅入深出Vue:工具准备之WebStorm安装配置

    浅入深出Vue之工具准备(一):WebStorm安装配置 工欲善其事必先利其器,让我们先做好准备工作吧 导航篇 WebStorm安装配置 所有工具的下载地址都可以在导航篇中找到,这里我们下载的是最新版 ...

  9. 浅入深出Vue系列

    浅入深出Vue导航 导航帖,直接点击标题即可. 文中所有涉及到的资源链接均在最下方列举出来了. 前言 基础篇 浅入深出Vue:工具准备之WebStorm搭建及配置 浅入深出Vue之工具准备(二):Po ...

随机推荐

  1. CSS制作三角形和按钮

    CSS制作三角形和按钮 用上一篇博文中关于边框样式的知识点,能制作出三角形和按钮. 我先说如何制作三角形吧,相信大家在平时逛网站的时候都会看到一些导航栏中的三角形吧,比如说: 网易首页的头部菜单栏中, ...

  2. &period;net framework体系结构

    CIL(common intermediate language):公共中间语言..net框架下各种种类.版本的编程语言在经过编译后生成的中间语言(后缀为.il),与平台无关.与语言无关,只要机器上运 ...

  3. 关于actionscript中新建一个sprite,设置大小(宽高)的问题。

    有一定as3开发经验的童鞋应该知道,新建一个sprite,是无法设置大小的,即时设置了,也不会生效,宽高还是为0,据说反而有副作用(http://www.cnblogs.com/yjmyzz/arch ...

  4. 使用JUnit4与JMockit进行打桩测试

    1. 何为Mock 项目中各个模块,各个类之间会有互相依赖的关系,在单元测试中,我们只关心被测试的单元,对于其依赖的单元并不关心(会有另外针对该单元的测试). 比如,逻辑层A类依赖了数据访问层B类的取 ...

  5. Linux中查看是否是固态硬盘(SSD)

       最近在准备测试,需要看看哪些机器挂载的是ssd硬盘,Google了一圈看到了许多方法,但都云里雾里的,不知道怎么确定.ssd硬盘貌似使用的也是scsi接口,所以根据盘符的名称也是判断不出来的.最 ...

  6. java 文件字节输出流

    Example10_5.java import java.io.*; public class Example10_5 { public static void main(String args[]) ...

  7. 外部SRAM实验,让STM32的外部SRAM操作跟内部SRAM一样(转)

    源:外部SRAM实验,让STM32的外部SRAM操作跟内部SRAM一样 前几天看到开源电子论坛(openedv.com)有人在问这个问题,我特意去做了这个实验,这样用外部SRAM就跟用内部SRAM一样 ...

  8. memcached经典问题和现象

    缓存刷新时间集中问题 某个缓存失效了,导致其他节点的缓存命中率下降, 缓存中缺失的数据 去数据库查询.短时间内,会造成数据库服务器崩溃 需要将缓存失效时间离散分布在访问量比较低的时间段 multige ...

  9. js运动例子1

    <!doctype html> <html> <head> <meta charset="utf-8"> <meta name ...

  10. spring cloud--------------------HystrixCommand使用

    一.注解使用: (一)注解同步执行 1.注解开启断路器功能 @EnableCircuitBreaker 2.方法事例 @HystrixCommand(fallbackMethod = "er ...