• 如何判断集合中是否存在某个元素——contains()

  1.List的contains(obj)方法

  实际上,List调用contains(Object obj)方法时,会遍历List中的每一个元素,然后再调用每个元素的equals()方法去跟contains()方法中的参数进行比较,如果有一个元素的equals()方法返回true则contains()方法返回true,否则所有equals()方法都不返回true,则ontains()方法则返回false。因此,重写了Course类的equals()方法,否则,testListContains()方法的第二条输出为false。

  2.Set的Contains(obj)方法

  当调用HashSet的contains(Object obj)方法时,其实是先调用每个元素的hashCode()方法来返回哈希码,如果哈希码的值相等的情况下再调用equals(obj)方法去判断是否相等,只有在这两个方法所返回的值都相等的情况下,才判定这个HashSet包含某个元素。因此,需重写Course类的hashCode()方法和equals()方法。

  以下代码测试List和Set的contains()方法:

  SetTest.java

package com.test.collection;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner; public class SetTest {
public List<Course> coursesToSelect;
private Scanner console;
public static Student student;
public SetTest() {
coursesToSelect = new ArrayList<Course>();
console = new Scanner(System.in);
}
public void testAdd() {
Course c1 = new Course("1", "数据结构");//创建课程对象的实例
Course c2 = new Course("2", "C语言");
Course c3 = new Course("3", "离散数学");
Course c4 = new Course("4", "汇编语言");
Course[] course = {c1, c2, c3, c4};
coursesToSelect.addAll(Arrays.asList(course));
} public void testForEach() {
System.out.println("有以下课程可以选择:(通过For Each)");
for (Object obj : coursesToSelect) {
Course c = (Course) obj;
System.out.println("课程:" + c.id + ":" + c.name);
}
} /**
* 测试List 的contains()方法
*/
public void testListContains() {
Course c = coursesToSelect.get(0);
System.out.println("取得课程:" + c.name);
System.out.println("课程【" + c.name + "】是否在备选课程中:" + coursesToSelect.contains(c)); Course c2 = new Course(c.id, c.name);
System.out.println("新创建课程:" + c2.name);
System.out.println("课程【" + c2.name + "】是否在备选课程中:" + coursesToSelect.contains(c2)); System.out.println("请输入课程名称:");
String courseName = console.next();
Course c3 = new Course();
c3.name = courseName;
System.out.println("课程【" + c3.name + "】是否在备选课程中:" + coursesToSelect.contains(c3)); } /*
* 创建学生并选课
*/
public void createStudentAndSelectCourse() {
student = new Student("1", "李雷"); for (int i = 0; i < 3; i++) {
System.out.println("请输入课程编号:");
String courseId = console.next();
for(Course c : coursesToSelect ) {
if (c.id.equals(courseId)) {
student.courses.add(c);
}
}
}
} public void testForEachForSet(Student student) {
System.out.println("共选择了" + student.courses.size() + "门课程!");
for (Course c : student.courses) {
System.out.println("选择了课程:" + c.id + ":" + c.name);
}
}
/**
* 测试Set的contains()方法
*/
public void testSetContains() {
System.out.println("请输入课程名称:");
String courseName = console.next();
Course c = new Course();
c.name = courseName;
System.out.println("所选择的课程中是否包含" + courseName + ":" + student.courses.contains(c)); } public static void main(String[] args) {
SetTest st = new SetTest();
st.testAdd();
st.testListContains();
st.createStudentAndSelectCourse();
st.testForEachForSet(SetTest.student);
st.testSetContains();
}
}

  Course类:

package com.test.collection;

/**
* 课程类
* @author Administrator
*
*/
public class Course {
public String id;
public String name;
public Course(String id, String name){
this.id = id;
this.name = name;
}
public Course() { }
@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 Course))
return false;
Course other = (Course) obj;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
}
  • Map中是否包含指定的Key和Value

  在Map中,用containsKey()方法,判断是否包含某个Key值;用containsValue()方法,判断是否包含某个Value值。

  以下是MapTest类的部分示例代码:

package com.test.collection;

public class MapTest {
public Map<String, Student> students;
public Scanner console;
public MapTest() {
this.students = new HashMap<String, Student>();
this.console = new Scanner(System.in);
}
public void testContainsKeyOrValue() {
System.out.println("请输入学生ID:");
String stuId = console.next();
System.out.println("是否有ID为" + stuId + "的学生:" + students.containsKey(stuId));
if (students.containsKey(stuId)) {
System.out.println("ID为" + stuId + "的学生的名字是:" + students.get(stuId).name);
}
System.out.println("请输入学生的姓名:");
String stuName = console.next();
Student st = new Student(null, stuName);
System.out.println("是否有姓名为" + stuName + "的学生:" + students.containsValue(st)); }
}

  注:跟List中的Contains()方法一样,Map中的ContainsValue()方法也需要调用某个Value值的equals()方法,去和参数对象进行比较,如果匹配成功,返回结果为true,说明在Map中的Value值确实包含参数对象。因此,需要重写Student类的equals()方法。

  Student类:

package com.test.collection;

import java.util.HashSet;
import java.util.Set;
/**
* 学生类
* @author Administrator
*
*/
public class Student {
public String id;
public String name;
public Set<Course> courses;//所选课程
public Student(String id, String name) {
this.id = id;
this.name = name;
this.courses = new HashSet<Course>();//实例化sourses接口(Set是接口,接口不能被直接实例化)
}
@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;
}
}

Java—集合框架 List和Set的contains()以及Map的containsKey()、containsValue()的更多相关文章

  1. java集合框架collection(3)Set、List和Map

    Set.List和Map是java collection中最常用的三种数据结构. Set是集合,不允许有重复的元素,List是动态数组实现的列表,有序可重复,Map是key-value的键值对,用于快 ...

  2. 浅入深出之Java集合框架(中)

    Java中的集合框架(中) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,如果已经有java基础的小伙伴可以直接跳到<浅入深出之Java集合框架 ...

  3. 浅入深出之Java集合框架(下)

    Java中的集合框架(下) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,哈哈这篇其实也还是基础,惊不惊喜意不意外 ̄▽ ̄ 写文真的好累,懒得写了.. ...

  4. Java—集合框架 Collections.sort()、Comparable接口和Comparator接口

    Collentions工具类--java.util.Collections Collentions是Java集合框架中,用来操作集合对象的工具类,也是Java集合框架的成员,与List.Map和Set ...

  5. Java集合框架List,Map,Set等全面介绍

    Java集合框架的基本接口/类层次结构: java.util.Collection [I]+--java.util.List [I]   +--java.util.ArrayList [C]   +- ...

  6. Java集合框架练习-计算表达式的值

    最近在看<算法>这本书,正好看到一个计算表达式的问题,于是就打算写一下,也正好熟悉一下Java集合框架的使用,大致测试了一下,没啥问题. import java.util.*; /* * ...

  7. 【集合框架】Java集合框架综述

    一.前言 现笔者打算做关于Java集合框架的教程,具体是打算分析Java源码,因为平时在写程序的过程中用Java集合特别频繁,但是对于里面一些具体的原理还没有进行很好的梳理,所以拟从源码的角度去熟悉梳 ...

  8. Java 集合框架

    Java集合框架大致可以分为五个部分:List列表,Set集合.Map映射.迭代器.工具类 List 接口通常表示一个列表(数组.队列.链表 栈),其中的元素 可以重复 的是:ArrayList 和L ...

  9. Java集合框架之map

    Java集合框架之map. Map的主要实现类有HashMap,LinkedHashMap,TreeMap,等等.具体可参阅API文档. 其中HashMap是无序排序. LinkedHashMap是自 ...

随机推荐

  1. elementui 给 左侧功能栏 加上 el-scroll 时 , el-main 会 挤压 左侧导航栏..

    解决方法... el-main 给上 style='width:0'........... 并不会影响 el-main 布局...

  2. 【算法笔记】B1048 数字加密

    1048 数字加密 (20 分) 本题要求实现一种数字加密方法.首先固定一个加密用正整数 A,对任一正整数 B,将其每 1 位数字与 A 的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对 ...

  3. 洛谷 P1560 [USACO5.2]蜗牛的旅行Snail Trails

    题目链接 题解 一看题没什么思路.写了个暴力居然可过?! Code #include<bits/stdc++.h> #define LL long long #define RG regi ...

  4. HDU_1028 Ignatius and the Princess III 【母函数的应用之整数拆分】

    题目: "Well, it seems the first problem is too easy. I will let you know how foolish you are late ...

  5. HDU 6325 Problem G. Interstellar Travel(凸包)

    题意: 给你n个点,第一个点一定是(0,0),最后一个点纵坐标yn一定是0,中间的点的横坐标一定都是在(0,xn)之间的 然后从第一个点开始飞行,每次飞到下一个点j,你花费的价值就是xi*yj-xj* ...

  6. BZOJ - 1497 最小割应用

    题意:基站耗费成本,用户获得利益(前提是投入成本),求最大获利 最小割的简单应用,所有可能的收益-(消耗的成本/失去的收益),无穷大边表示冲突,最小割求括号内的范围即可 #include<ios ...

  7. UESTC - 1692 注意DP顺序

    #include<iostream> #include<algorithm> #include<cstdio> #include<cstring> #i ...

  8. ACM 计算几何向量

    向量 简介注意事项基本计算 加减法 ~ 示例代码 长度 ~ 示例代码 数乘 ~ 示例代码 点积 应用 ~ 示例代码 叉积 ~ 示例代码 性质与应用 经典题目 向量旋转 操作目的 模板代码 简介 向量, ...

  9. Http多线程下载文件

    package unit; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileOutputSt ...

  10. Oracle 11g使用DML Error Logging来避免bulk insert故障

    当使用带有子查询的insert语句来加载数据时如果出现错误.系统会终止该语句并回滚整个操作.这是非常消耗时间和资源的操作.如果insert这样的语句可以使用DML Error Logging功能来避免 ...