在实际项目中我们通常会有一个需求就是:想知道在一个列表中是否包含某一个对象

这里ArrayList表、HashSet表和HashMap表都提供了一个contains(obj)方法,

下面说一下两个列表contains(obj)方法的实现原理。

ArrayList表:

先遍历表中每个元素(对象),然后对每个元素执行一个equals(obj)方法,该方法返回

一个布尔值。然而,通常我们查询的时候并不会将一个对象的所有属性值都输入,可能

只输入一个具有代表性的属性值,比如name属性,这个时候就要我们来修改equals(obj)

方法了,在内部if语句比较的时候只比较obj.name属性值和当前列表元素的name属性值。

public boolean equals(Object obj) {
              if (this == obj)
                      return true;                  //比较对象和当前元素相同,返回true
              if (obj == null)
                      return false;                //比较对象为空,返回false
              if (!(obj instanceof Courses))
                      return false;                //比较对象类型和当前元素不同,返回false
              Courses other = (Courses) obj;
              if (name == null) {
                      if (other.name != null)
                                 return false;     //当前元素name为空,而比较对象name不为空,返回false
              } else if (!name.equals(other.name))
                      return false;                //当前元素name和比较对象name不相同,返回false

return true;                         //排除以上因素后,该函数才返回true
}

HashSet表:

值得一提的是,HashSet表的contains(obj)方法实现,不仅要比较属性值字段是否匹配,还要

比较哈希码值(经过哈希算法返回的一个int型数据),两者都为true,contains(obj)方法才返

回true。于是我们就还要再重写一下表内对象的hashCode()函数来只返回特定属性值(name)

的哈希码值。

public int hashCode() {
            final int prime = 31;
            int result = 1;
            result = prime * result + ((name == null) ? 0 : name.hashCode());
            return result;
}

注意,这是eclipse软件生成的hashCode()函数,只返回name属性的哈希码值,其实函数内部

真正有意义的只有黑色加粗的这个hashCode()函数,这个函数的具体算法我们不做深究,result只

是对name的哈希码值作进一步处理。切记,蓝色的hashCode()函数是我们自己定义的,而黑色加粗

的hashCode()函数是引自java的哈希码算法函数,不要搞混了!!!

有兴趣的同学可以看一下哈希算法是怎么实现的~~~

HashMap表:

Map表由于是键值对的形式,所以就有两种contains()方法:containsKey(Key)和containsValue(obj)

containsKey(Key)方法很明显,传入一个Key值,然后进行键值的匹配。

而containsVaule(obj),由于是一个对象,匹配的时候会根据具体属性来匹配,这就需要重写指定属性例如

name的equals(obj)方法。另外提一点,containsVaule(obj)里面的obj可以这样写new Course(null,name),

因为比较的时候只比较了obj.name属性,所以id属性可以索性为空(null)!

还有个方法内部实现也用到equals(obj),list.indexOf(obj),将obj与List列表的每一项,用equal(obj)逐个比较,

当然也只是比较特定属性,当equals()方法返回true时,将此项的索引值返回给indexOf(obj)函数。

java集合的contains(obj)方法的实现的更多相关文章

  1. java学习-Comparable<Integer>接口方法的实现

    基本数据类型的包装类Integer, Float, Double,Long,Byte等都实现的Comparable接口,用于列表List或数组arrays的排序 Comparable<Integ ...

  2. 关于Java中常用加密/解密方法的实现

    安全问题已经成为一个越来越重要的问题,在Java中如何对重要数据进行加密解密是本文的主要内容. 一.常用的加密/解密算法 1.Base64 严格来说Base64并不是一种加密/解密算法,而是一种编码方 ...

  3. 【Java安全】关于Java中常用加密/解密方法的实现

    安全问题已经成为一个越来越重要的问题,在Java中如何对重要数据进行加密解密是本文的主要内容. 一.常用的加密/解密算法 1.Base64 严格来说Base64并不是一种加密/解密算法,而是一种编码方 ...

  4. Java—集合框架 List的 indexOf()、lastIndexOf()

    集合中某个元素出现的位置—List的indexOf(),lastIndexOf() indexOf(Object obj)方法的实现机制是从序列(List)的第0个元素开始依次循环,并且调用每个元素的 ...

  5. 05_动手动脑之String.equals()方法的实现代码

    Question: 请查看String.equals()方法的实现代码,注意学习其实现方法. Answer: java中的String.equals()方法的实现代码: equals()法是根类Obj ...

  6. 关于Java中hashCode方法的实现源码

    首先来看一下String中hashCode方法的实现源码. public int hashCode() { int h = hash; if (h == 0 && value.leng ...

  7. Java集合框架实现自定义排序

    Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优 ...

  8. Java集合面试题

    1.Java集合框架是什么?说出一些集合框架的优点? 每种编程语言中都有集合,最初的Java版本包含几种集合类:Vector.Stack.HashTable和Array.随着集合的广泛使用,Java1 ...

  9. 【JAVA集合框架之Set】

    一.Set概述. Set集合的特点是元素不允许重复,而且是无序的(添加和取出的顺序不一致). Set接口中的方法和Collection接口中的方法几乎相同,略. Set接口下常用的两个类:HashSe ...

随机推荐

  1. XML解析之sax解析案例(一)读取contact.xml文件,完整输出文档内容

    一.新建Demo2类: import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXPar ...

  2. iOS中 用FMDB封装一个SQLite数据库

    建立一个单例: DataBaseHandle.h #import <Foundation/Foundation.h> @class PersonModel; @class FMDataba ...

  3. 05_学生管理系统,xml读写,布局的综合应用

     最终要做的项目目标: 2.编写Android清单文件AndroidManifest.xml <?xml version="1.0" encoding="utf ...

  4. c语言和java的区别

    今晚读了一下c程序设计语言,这是一本经典书籍,发现C语言和java有很多是相同的,毕竟java是由c语言进化来的. 我大概从我自己的思考来谈谈不同点 1.c语言是面向过程,主要单位是函数,变量和函数的 ...

  5. Android安全机制浅谈-android学习之旅(80)

    由于Android安全机制存在,使得漏洞利用有一些困难. ASLR:即地址空间格局随机化.ASLR使得加载程序时不使用固定的基址加载,防止攻击者直接定位攻击代码位置,从而阻止溢出攻击 NX:(No e ...

  6. 如何反编译APK?

    1.概述 一些商业的app都包含很多精美的图片还有一些比较好的配置文件,以前某师兄就说过apk把后缀改为zip,然后解压一下就可以获得很多图片资源,但是这时候你打开一下解压出来的xml资源全是乱码.通 ...

  7. 某集团BI决策系统建设方案分享

    企业核心竞争能力的提升,需要强壮的运营管理能力,需要及时.准确.全面的业务数据分析作为参考与支撑. 某集团是大型时尚集团,内部报表系统用的QlikView,但是管理分配不够灵活,不能满足数据安全的要求 ...

  8. FFMPEG结构体分析:AVFrame

    注:写了一系列的结构体的分析的文章,在这里列一个列表: FFMPEG结构体分析:AVFrameFFMPEG结构体分析:AVFormatContextFFMPEG结构体分析:AVCodecContext ...

  9. Android服务器——使用TomCat实现软件的版本检测,升级,以及下载更新进度!

    Android服务器--使用TomCat实现软件的版本检测,升级,以及下载更新进度! 算下来,TomCat服务器已经写了很长一段时间了,一直说拿他来搞点事 情,也一直没做,今天刚好有空,交流群还有人请 ...

  10. LeetCode之“散列表”:Single Number

    题目链接 题目要求: Given an array of integers, every element appears twice except for one. Find that single ...