• Map和HashMap

  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值不可重复)

  

  • 学生选课——使用Map添加学生
  • 学生选课——删除Map中的学生
  • 学生选课——修改Map中的学生

package com.imooc.collection;

import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Scanner;
import java.util.Set;

public class MapTest {
    //用来承装学生类型对象
    public Map<String,Student>students;
    /*在构造器中初始化students属性*/
    public MapTest(){
        this.students=new HashMap<String,Student>();
    }
    /**
     * 测试添加:输入学生ID,判断是否被占用
     * 若薇被占用,则输入姓名,创建新学生对象,并且
     * 添加到student中
     */
    public void testPut(){
        Scanner console=new Scanner(System.in);
        int i=0;
        while (i<3) {
            System.out.println("请输入学生ID");
            String ID=console.next();
            Student st=students.get(ID);
            if (st==null) {
                //提示输入学生姓名
                System.out.println("请输入学生姓名");
                String name=console.next();
                //添加新的学生对象
                Student newStudent=new Student(ID,name);
                students.put(ID,newStudent);
                System.out.println("成功添加学生:"+students.get(ID).name);
                i++;
            }else{
                System.out.println("该学生ID已被占用");
                continue;
            }
        }
    }
    /**
     * @param args测试Map的keySet方法
     */

    public void testKeySet(){
        //keySet方法,返回Map中的所有“键”的Set集合
        Set<String> keySet=students.keySet();
        //取得student的容量
        System.out.println("总共有:"+students.size()+"个学生");
        //遍历keySet,取得每一个键,再调用get方法取得每个键对应的value
        for (String stuId : keySet) {
            Student st=students.get(stuId);
            if (st!=null) {
                System.out.println("学生"+st.name);
            } 

        }
    }

    /**
     * 测试删除Map中的映射
     */
    public void testRemove(){

        //获取从键盘输入待删除学生ID字符串
        Scanner console=new Scanner(System.in);
        while (true) {
            //提示输入待删除的学生ID
            System.out.println("请输入要删除的学生ID");
            String ID=console.next();
            //判断该ID是否有对应的学生对象
            Student st=students.get(ID);
            if (st==null) {
                //提示输入的ID并不存在
                System.out.println("该ID不存在");
                continue;
            }
            students.remove(ID);
            System.out.println("成功删除学生"+st.name);
            break;
        }
    }
    /**
     * 通过entrySet方法来遍历Map
     */
    public void testEntrySet(){
        //通过entrySet方法,返回Map中的所有键值对
        Set<Entry<String,Student>> entrySet=students.entrySet();
        for (Entry<String, Student> entry : entrySet) {
            System.out.println("取得键"+entry.getKey());
            System.out.println("对应的职为:"+entry.getValue().name);
        }
    }

    /**
     * 利用put方法修改Map中的已有映射
     */
    public void testModify(){
        //提示输入要修改的学生ID
        System.out.println("请输入要修改的学生ID:");
        //创建Scanner对象,去获取从键盘上输入的学生ID字符串
        Scanner console=new Scanner(System.in);
        while(true){
            //取得从键盘上输入的学生ID
            String stuID=console.next();
            //从students中查找该学生ID对应的学生对象
            Student student=students.get(stuID);
            if (student==null) {
                System.out.println("该ID不存在,重新输入!");
                continue;
            }
            //提示当前对应的学生对象的姓名
            System.out.println("当前该学生ID,所对应的学生为:"+student.name);
            //提示输入新的学生姓名,来修改已有的映射
            System.out.println("请输入新的学生姓名");
            String name=console.next();
            Student newStudent=new Student(stuID,name);
            students.put(stuID,newStudent);
            System.out.println("修改成功!");
            break;
        }
    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        MapTest mt=new MapTest();
        mt.testPut();
        mt.testKeySet();
        /*mt.testRemove();
        mt.testEntrySet();*/
        mt.testModify();
        mt.testEntrySet();
    }

}

Java中的集合框架(中)的更多相关文章

  1. 菜鸟日记之 java中的集合框架

    java中的集合框架图 如图所示:java中的集合分为两种Collection和Map两种接口 可分为Collection是单列集合和Map的双列集合 Collection单列集合:继承了Iterat ...

  2. Java中的集合框架(下)

    学生选课--判断Set中课程是否存在 package com.imooc.collection; import java.util.ArrayList; import java.util.Arrays ...

  3. Java中的集合框架(上)

    Java中的集合框架概述 集合的概念: Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象. 集合的作用: 1.在类的内部,对数据进行组织: 2.简单的快速的搜索大数据量的 ...

  4. 第49节:Java集合框架中底层文档的List与Set

    Java集合框架中的List与Set // 简书作者:达叔小生 Collection -> Set 无序不重复 -> 无序HashSet,需要排序TreeSet -> List 有序 ...

  5. Java集合框架中的快速失败(fail—fast)机制

      fail-fast机制,即快速失败机制,是java集合框架中的一种错误检测机制.多线程下用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(增加.删除),则会抛出Concurre ...

  6. Java中的集合框架-Collections和Arrays

    上一篇<Java中的集合框架-Map>把集合框架中的键值对容器Map中常用的知识记录了一下,本节记录一下集合框架的两个工具类Collections和Arrays 一,Collections ...

  7. Java中的集合框架-Map

    前两篇<Java中的集合框架-Commection(一)>和<Java中的集合框架-Commection(二)>把集合框架中的Collection开发常用知识点作了一下记录,从 ...

  8. Java中的集合框架-Collection(二)

    上一篇<Java中的集合框架-Collection(一)>把Java集合框架中的Collection与List及其常用实现类的功能大致记录了一下,本篇接着记录Collection的另一个子 ...

  9. Java:类集框架中集合的学习

    Java:类集框架中集合的学习 集合 Java:Set的学习 Set是类集框架中的集合类.集合是不按特定的方式排序,并且没有重复对象的一种类. Q:Set如何操作?Set中的不按特定方式排序是怎么排序 ...

  10. 牛客网Java刷题知识点之Java 集合框架的构成、集合框架中的迭代器Iterator、集合框架中的集合接口Collection(List和Set)、集合框架中的Map集合

    不多说,直接上干货! 集合框架中包含了大量集合接口.这些接口的实现类和操作它们的算法. 集合容器因为内部的数据结构不同,有多种具体容器. 不断的向上抽取,就形成了集合框架. Map是一次添加一对元素. ...

随机推荐

  1. mysql查询进程、导入数据包大小设置

    mysql查询进程.导入数据包大小设置 zoerywzhou@163.com http://www.cnblogs.com/swje/ 作者:Zhouwan 2017-12-27 查询正在执行的进程: ...

  2. MyEclipse 2014 破解版下载:我有,需要的给我说一声,给你发过去

    1.破解版的,需要的在下面给我说一声,云盘给你发过去.

  3. centos6.5安装禅道

    1.安装禅道需要安装以下环境 mysql php 5 apache 2 2.安装命令 1.安装mysql yum install mysql mysql-server 2.安装apache yum i ...

  4. InfluxDb中写入重复数据问题解决方案

    1.InfluxDb版本 0.10.3 2.Measurement TodayChargeTimeReport 只有time和Field列,没有Tag列 3.现象:通过定时任务向上面的表中写入数据: ...

  5. 【MySQL】查看支持的字符集show character set;

  6. JavaScript数字例子,二分法,冒泡排序

    先看一下两个例子: 十个成绩,求总分,最高分,最低分 //输入10个成绩,求总分,最高,最低 var arr=new Array(67,45,56,12,90,98,23,43,56,99,97); ...

  7. 网友"就像一支烟"山寨币分析估值方法

    [注:素材取自QQ群,2017年12月28日的聊天记录."就像一支烟"分享了自己的山寨币分析估值方法.因为删去了其他人的聊天记录,部分文字可能断章取义,仅供参考,具体情况请自行分析 ...

  8. http中的get和post(二)

    博客园精华区有篇文章< GET 和 POST 有什么区别?及为什么网上的多数答案都是错的 >,文中和回复多是对以下两个问题进行了深究: 长度限制 Url 是否隐藏数据 在我看来这两者都不是 ...

  9. ArcGIS 网络分析[2.2] 服务区分析

    什么是服务区? 我们先提一个很常见的社会现象:一个医院,如果要发起抢救,那么10分钟内能去多远? 时间就是生命,当结合道路网的阻力进行最短路径分析时,得到的可达的覆盖区域,这个区域就是服务区. 服务区 ...

  10. 浅谈对ST表的一些理解

    今天打了人生第一道ST表题(其实只是ST表跑得最快); ST表是一种用来解决RMQ问题的利器... 大体操作有两步: 第一部分nlogn预处理 第二部分O(1)询问 预处理就是运用倍增+区间动规 ST ...