HashMap查找之根据Value查找

一般大家都知道对于HashMap而言都是通过key来进行查找。找到了key自然对应的value也就一并找到了。但是有些情况下就需要通过value来进行判断查找。说是查找不如说筛选更为恰当。

那么什么情况下会用到这种vaule查找方式呢?让我们一起来看一下以下代码就清楚了。

【1】面向对象学生类的创建

 package com.java.demo_9;

 /**
* Student类
* @author liupeng
*
*/
public class Student { private String stuName;
private String classCord;
private String stuNumber;
public String getStuName() {
return stuName;
}
public void setStuName(String stuName) {
this.stuName = stuName;
}
public String getClassCord() {
return classCord;
}
public void setClassCord(String classCord) {
this.classCord = classCord;
}
public String getStuNumber() {
return stuNumber;
}
public void setStuNumber(String stuNumber) {
this.stuNumber = stuNumber;
}
public Student() {
super();
// TODO Auto-generated constructor stub
}
public Student(String stuName,String stuNumber,String classCord) {
super();
this.stuName = stuName;
this.classCord = classCord;
this.stuNumber = stuNumber;
}
@Override
public String toString() {
return "学员名称:" + stuName + ", 学员编号:"
+ stuNumber + ", 班级番号:" + classCord;
} }

Student(学生类)

【2】面向对象筛选出相同classCord的同学

package com.java.demo_9;

import java.util.ArrayList;
import java.util.HashMap; public class HashMapTest2 {
public static void main(String[] args) {
HashMap map = new HashMap();   //HashMap字典的创建并遍历出各个元素 System.out.println("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++");
System.out.println("\t\t<学员信息一览表>\t\t");
System.out.println();
Student st1 = new Student("王小天", "cn0001", "class0001");
Student st2 = new Student("张天爱", "cn0002", "class0002");
Student st3 = new Student("武则天", "cn0003", "class0003");
Student st4 = new Student("小钢炮", "cn0004", "class0004");
Student st5 = new Student("屠龙刀", "cn0005", "class0002");
Student st6 = new Student("小龙女", "cn0008", "class0002");
Student st7 = new Student("三毛", "cn0006", "class0001");
Student st8 = new Student("杨过", "cn0007", "class0002"); map.put("王小天", st1);
map.put("张天爱", st2);
map.put("武则天", st3);
map.put("小钢炮", st4);
map.put("屠龙刀", st5);
map.put("小龙女", st6);
map.put("三毛", st7);
map.put("杨过", st8); for (Object key : map.keySet()) {
// System.out.println(key);
Student value = (Student) map.get(key);
System.out.println(key + ":" + value);
} System.out.println("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++");
System.out.println();
//创建3个ArrayList列表便于接受数据
ArrayList list1 = new ArrayList();
ArrayList list2 = new ArrayList();
ArrayList list3 = new ArrayList();

          //通过for循环,if else循环语句来筛选隶属于相同班级的学生(list3例外)
for(Object key:map.keySet()){
Student obj = (Student)map.get(key);
System.out.println(obj);
if(obj.getClassCord().contains("class0002")){
list1.add(obj);
}else if(obj.getClassCord().indexOf("class0001")!=-1){
list2.add(obj);
}else{
list3.add(obj);
}
}           //分别遍历出筛选过后的结果
System.out.println("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++");
System.out.println("[class0002班级的学生有:]");
System.out.println(); for(Object obj:list1)
System.out.println(obj); System.out.println("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++");
System.out.println("[class0001班级的学生有:]");
System.out.println(); for(Object obj:list2)
System.out.println(obj); System.out.println("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++");
System.out.println("[其他班级的学生有:]");
System.out.println(); for(Object obj:list3)
System.out.println(obj); } }

结果:

【HashMap原字典信息】

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++
<学员信息一览表> 三毛:学员名称:三毛, 学员编号:cn0006, 班级番号:class0001
屠龙刀:学员名称:屠龙刀, 学员编号:cn0005, 班级番号:class0002
张天爱:学员名称:张天爱, 学员编号:cn0002, 班级番号:class0002
小龙女:学员名称:小龙女, 学员编号:cn0008, 班级番号:class0002
杨过:学员名称:杨过, 学员编号:cn0007, 班级番号:class0002
小钢炮:学员名称:小钢炮, 学员编号:cn0004, 班级番号:class0004
王小天:学员名称:王小天, 学员编号:cn0001, 班级番号:class0001
武则天:学员名称:武则天, 学员编号:cn0003, 班级番号:class0003
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

【属于class0002班级学员的信息】

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

[class0002班级的学生有:]

学员名称:屠龙刀, 学员编号:cn0005, 班级番号:class0002
学员名称:张天爱, 学员编号:cn0002, 班级番号:class0002
学员名称:小龙女, 学员编号:cn0008, 班级番号:class0002
学员名称:杨过, 学员编号:cn0007, 班级番号:class0002
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

【属于class0001班级学员的信息】

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++
[class0001班级的学生有:] 学员名称:三毛, 学员编号:cn0006, 班级番号:class0001
学员名称:王小天, 学员编号:cn0001, 班级番号:class0001
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

【其他班级学员的信息】

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++
[其他班级的学生有:] 学员名称:小钢炮, 学员编号:cn0004, 班级番号:class0004
学员名称:武则天, 学员编号:cn0003, 班级番号:class0003
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

总结:

1. 创建3个ArrayList列表分别用来存放不同班级的信息.

2. 通过if ,else if ,else语句来判断属于不同班级的学生(根据classCord来判断)

3. 通过面向对象的方法调用Student类中.getClassCord()获取到classCord.

4. 通过.contains("元素"),.indexOf("元素")!=-1的任意一种方式结合if,else语句来进行筛选判断.

5. 分别遍历3个ArrayList中存入的元素.

方法很简单,相信java大神们肯定有更便捷的方法同样能够做到更好的效果。但是我是java初学者,这篇文章在此的目的只是希望能够帮助跟我一样初学java的同学们。

希望能有所帮助,谢谢。

【补充版】HashMap(根据value筛选查找)的更多相关文章

  1. 详解什么是平衡二叉树(AVL)(修订补充版)

    详解什么是平衡二叉树(AVL)(修订补充版) 前言 Wiki:在计算机科学中,AVL树是最早被发明的自平衡二叉查找树.在AVL树中,任一节点对应的两棵子树的最大高度差为1,因此它也被称为高度平衡树.查 ...

  2. java 中linq 的使用方式 筛选 查找 去重

    1.筛选 $.Enumerable.From(value).Where(function(x) {//value 为被操作的内容 return x.name == name;//第一个name为val ...

  3. python基础语法20 面向对象5 exec内置函数的补充,元类,属性查找顺序

    exec内置函数的补充 exec: 是一个python内置函数,可以将字符串的代码添加到名称空间中; - 全局名称空间 - 局部名称空间 exec(字符串形式的代码, 全局名称空间, 局部名称空间) ...

  4. 有趣的条漫版 HashMap,25岁大爷都能看懂

    我是风筝,公众号「古时的风筝」,一个兼具深度与广度的程序员鼓励师,一个本打算写诗却写起了代码的田园码农! 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在 ...

  5. 数据结构(C语言版)-第7章 查找

    7.1 查找的基本概念 查找表:    由同一类型的数据元素(或记录)构成的集合静态查找表:    查找的同时对查找表不做修改操作(如插入和删除)动态查找表:    查找的同时对查找表具有修改操作关键 ...

  6. 深入理解HashMap(原理,查找,扩容)

    面试的时候闻到了Hashmap的扩容机制,之前只看到了Hasmap的实现机制,补一下基础知识,讲的非常好 原文链接: http://www.iteye.com/topic/539465 Hashmap ...

  7. linux下命令的全称,方便记忆(转)-修改补充版

    su:Swith user  切换用户,切换到root用户 cat: Concatenate  串联(cat(Concatenate)命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容, ...

  8. 面经手册 · 第4篇《HashMap数据插入、查找、删除、遍历,源码分析》

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 在上一章节我们讲解并用数据验证了,HashMap中的,散列表的实现.扰动函数.负载因 ...

  9. mongodb索引--1亿条记录的查询从55.7秒到毫秒级别<补充版>

    从头开始,验证mongodb的索引的好处.(window7环境下) 下载mongodb服务器,并解压到d盘,并使用以下命令启动 mongod --dbpath D:\mongodb\data mong ...

随机推荐

  1. Modelsim-altera 仿真 顶层原理图设计的FPGA

    我的原理图采用的是bdf的顶层原理图的设计,仿真工具用的是modelsim-altera,调用仿真后的错误提示: # ** Error: (vsim-3033) C:/Users/lenovo/Des ...

  2. 慕课网-Java入门第一季-6-7 使用 Arrays 类操作 Java 中的数组

    来源:http://www.imooc.com/code/1556 Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现 ...

  3. oracle基础语法大全

    -----创建序列create sequence book_idINCREMENT BY 1 -- 每次加几个 START WITH 001 -- 从1开始计数 NOMAXVALUE -- 不设置最大 ...

  4. click 事件 arguments.callee 每次点击自动* 2

    今天在测试JQUERY(版本3.0,向下兼容3.0)时发现一个很特别的现象,代码如下: $($('button').get(4)).click(function(){ alert($(this).ht ...

  5. es6 static

    static 定义的是类的方法只有类能调用,而普通方法是实例的方法只有类实例能调用.变量也一样. class A { static fn() { console.log('sss'); } fn2() ...

  6. leetcode 191

    191. Number of 1 Bits Write a function that takes an unsigned integer and returns the number of ’1' ...

  7. Ninject之旅之六:Ninject约定

    摘要 在小的应用系统中一个一个注册一些服务类型不怎么困难.但是,如果是一个实际的有上百个服务的应用程序呢?约定配置允许我们使用约定绑定一组服务,而不用一个一个分别绑定. 要使用约定配置,需要添加Nin ...

  8. ue4标签测试与总结(UPROPERTY)

    学习UE4框架中的标签,本篇是总结成员变量标签UPROPERTY. 引擎版本:4.12.5 前期准备: 1.新建项目,C++空模板,新建C++类,继承AActor,名称MyActor. 使用TestA ...

  9. IT在线笔试总结(二)

    1. 循环队列的长度计算:对于非循环队列,尾指针与头指针的差值便是队列长度,而对于循环队列,差值可能为负数,因此需要将差值加上MAXQSIZE再与MAXQSIZE求余. 2. 算法的时间复杂度取决于: ...

  10. gb2312

    ---恢复内容开始--- 字符集 gb2312(字全)采用2两个字节(一个汉字) utf-8(只有汉字)采用3个字节(一个汉字) html就是负责描述页面的语义:css负责描述页面的样式:js负责描述 ...