mooc_java 集合框架中 学生所选课程2Map&HashMap

Map&HashMap
Map提供映射关系,元素以键值对形式存储,Map的键值对一Entry类型的对象实例形式存在,key值不能重复,value可以
键最多能映射到一个值,支持泛型 Map<K,V>
HashMap是Map的一个重要实现类,基于哈希表实现,其中的Entry对象是无序排列的,key和value值都可以为null,但只能有一个key值为null的映射(key值不可以重复)

public class MapTest {
    /**
     * 承装学生类型对象
     */
    public Map<String, Student> students;
    public MapTest(){
        this.students=new HashMap<String,Student>();
    }
    /**
     * 测试添加:输入学生Id,判断是否被占用
     * 若为被占用,则输入姓名,创建学生对象,并且添加到students中
     * @param args
     */
    public void testPut(){
        //创建Scanner对象,用来获取输入的学生ID和姓名
        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 news=new Student(ID, name);
                //调用students的put方法,添加ID-学生映射
                students.put(ID,news);
                System.out.println("成功添加学生:"+students.get(ID).name);                
                i++;
            }
            else{
                System.out.println("该学生ID已被占用");
                continue;
            }
        }
    }
    
    /**
     * 测试Map的keySet方法
     * @param args
     */
    public void testKeySet(){
        //已经规定泛型为String类型
        Set<String> ks=students.keySet();
        //取得students的容量
        System.out.println("总共有:"+students.size()+"个学生");
        //遍历KeySet,取得每一个键,再调用个体方法取得每个键对应的value
        for(String stuId:ks){
            Student st=students.get(stuId);
            if(st!=null)
                System.out.println("学生:"+st.name);
        }
    }
    
    /**
     * 测试删除Map中的映射
     * @param args
     */
    public void testRemove(){
        //获取从键盘输入的待删除学生ID字符串
        Scanner console=new Scanner(System.in);
        while(true){
            System.out.println("输入要删除的学生ID");
            String stuID=console.next();
            //判断是否有对应的学生对象
            Student st=students.get(stuID);
            if(st==null){
                //提示输入的ID并不存在
                System.out.println("该ID不存在");
                continue;
            }
            students.remove(stuID);
            System.out.println("成功删除学生"+st.name);
            break;
        }
    }
    /**
     * 通过entrySet方法来遍历Map
     */
    public void testEntrySet(){
        //entrySet方法返回Map的所有键值对
        //Set<Entry> es=students.entrySet();
        Set<Entry<String,Student>> es=students.entrySet();
        for(Entry<String,Student> entry:es){
            System.out.println("取得键为:"+entry.getKey());
            System.out.println("值为为:"+entry.getValue().name);            
        }
    }
    /**
     * put方法修改Map中 已有的映射
     * @param args
     */
    public void testModify(){
        System.out.println("请输入要修改的学生的ID:");
        Scanner console=new Scanner(System.in);
        while(true){
            String stuID=console.next();
            //判断是否有对应的学生对象
            Student st=students.get(stuID);
            if(st==null){
                //提示输入的ID并不存在
                System.out.println("该ID不存在");
                continue;
            }
            else{
                System.out.println("当前学生ID对应:"+st.name);
                System.out.println("请输入新的学生姓名 :");
                String name=console.next();
                Student ns=new Student(stuID, name);
                students.put(stuID, st);
                System.out.println("修改成功");
                break;
            }
        }
    }
    
    public static void main(String[] args) {
        MapTest mt=new MapTest();
        mt.testPut();
        mt.testKeySet();
        mt.testRemove();
        mt.testEntrySet();
        mt.testModify();
        mt.testEntrySet();
    }

}
在平凡中坚持前行,总有一天,会遇见优秀的自己
原文地址:https://www.cnblogs.com/mao-19/p/4961684.html