java map特性_JAVA集合框架Map特性及实例解析

一  Map特性:

1 Map提供一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value;

2 Map中键值对以Entry类型的对象实例形式存在;

3 键,即key不可重复,但是value值可以;

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

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

6 Map支持泛型,形式如:Map

二  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 students = new HashMap();

/*

* 新建学生到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 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 = new HashSet();

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-学生姓名:张飞

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值