【慕课笔记】第六章 JAVA中的集合框架(下) 第4节 学生选课——判断Map中是否包含指定的key和value

第4节 学生选课——判断Map中是否包含指定的key和value


	//测试Map中是否包含某个key或者value值
	public void testContainsKeyOrValue(){
		//提示输入学生id
		System.out.println("请输入要查询的学生Id:");
		Scanner scanner=new Scanner(System.in);
		//在Map中使用containsKey()方法,来判断是否包含某个key值
		String id=scanner.next();
		System.out.println("您输入的学生id为:"+id+"是否包含此Key:"+students.containsKey(id));
		if(students.containsKey(id)){
			System.out.println("对应的学生为:"+students.get(id).name);
		}
		//在Map中使用containsValue()方法,来判断是否包含某个Value值
		//提示输入学生姓名
		System.out.println("请输入学生姓名:");
		String name=scanner.next();
		if(students.containsValue(new Student(null,name)))
			System.out.println("在学生映射表中确实包含该学生"+name);
		else
			System.out.println("映射表中不包含该学生!");
	}

containsValue()也要调用equals和hashcode方法,此处比较学生姓名,仅对name重写这两个方法

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (!(obj instanceof Student))
			return false;
		Student other = (Student) obj;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值