Java存储没有重复元素的数组


Posted in Java/Android onApril 29, 2022

Set接口

        Set接口和List接口一样,继承Collection接口,Set接口中元素无序,并且都会以某种规则保证存入的元素不出现重复。

HashSet集合

       HashSet是Set接口的一个实现类,所存储的元素是不可重复的,并且元素都是无序的,当向HashSet集合中添加一个对象时,首先会调用该对象的hashCode()方法来计算对象的哈希值,从而确定元素的存储位置。如果此时哈希值相同,再调用对象的equals()方法来确保该位置没有重复元素。

package 集合类;
 import java.util.HashSet;
 import java.util.Iterator;
 public class Set {
     public static void main(String[] args) {
         HashSet set=new HashSet();
         set.add("hello");
         set.add("world");
         set.add("abc");
         set.add("hello");
         Iterator it=set.iterator();
         while(it.hasNext()){
             Object obj=it.next();
             System.out.print(obj+ " ");
         }
     }
 }

运行结果

Java存储没有重复元素的数组

         由运行结果可以看出,取出元素的顺序和添加元素的顺序并不一致,并且重复的字符串被去掉了,只添加了一次,是因为HashSet集合的add()方法存入元素时,首先调用当前存入对象的hashCode()方法获得对象的哈希值,然后根据哈希值算出一个存储位置,如果这个位置上没有元素,则直接将该元素存入,如果该位置上有元素存在,则会调用equal()方法让当前存入的元素依次和该位置上的元素比较。如果返回结果为false就将该元素存入集合,返回结果为true,则说明有重复元素,将该元素舍弃。

package 集合类;
 import java.util.HashSet;
 class Student{
     String id;
     String name;
     public Student(String id,String name){
         this.id=id;
         this.name=name;
     }
     public String toString(){
         String s = id + ":" + name;
         return s;
     }
 }
 public class Set1 {
     public static void main(String[] args) {
         HashSet hs=new HashSet();
         Student stu1=new Student("1","hello");
         Student stu2=new Student("2","world");
         Student stu3=new Student("1","hello");
         hs.add(stu1);
         hs.add(stu2);
         hs.add(stu3);
         System.out.println(hs);
     }
 }

运行结果

Java存储没有重复元素的数组  

     所没有去掉重复的元素,是因为在定义Student类时没有重写hashCode()和equals()方法。

package API;
 import java.util.HashSet;
 class Student{
     private String id;
     private String name;
     public Student(String id,String name){
         this.id=id;
         this.name=name;
     }
     //重写toString方法
     public String toString(){
         return id+ ":"+name;
     }
     //重写hashCode方法
     public int hashCode(){
         //返回id属性的哈希值
         return id.hashCode();
     }
     public boolean equals(Object obj){
         //判断是否是同一个对象
         if(this==obj){
             return true;
         }
         //判断对象是Student类型
         if(!(obj instanceof Student)){
             return false;
         }
         //将对象强转为Student类型
         Student stu=(Student)  obj;
         //判断id是否相同
         boolean b=this.id.equals(stu.id);
         return b;
     }
 }
 public class Set2 {
     public static void main(String[] args) {
         HashSet hs=new HashSet();
         Student stu1=new Student("1","hello");
         Student stu2=new Student("2","world");
         Student stu3=new Student("1","hello");
         hs.add(stu1);
         hs.add(stu2);
         hs.add(stu3);
         System.out.println(hs);
     }
 }

运行结果

         由于Student类重写了Object类的hashCode()和equals()方法。在hashCode()方法中返回id属性的哈希值,在equals()方法中比较对象的id属性是否相等,并返回结果。当调用HashSet集合的add()方法添加stu3对象时,发现它的哈希值与stu2对象相同,而且stu2.equals(stu3)返回true。HashSet认定两个对象相同,因此重复的Student对象被去除了。

Java存储没有重复元素的数组

到此这篇关于Java如何使用Set接口存储没有重复元素的数组的文章就介绍到这了!


Tags in this post...

Java/Android 相关文章推荐
分析Netty直接内存原理及应用
Jun 14 Java/Android
Java用自带的Image IO给图片添加水印
Jun 15 Java/Android
分析设计模式之模板方法Java实现
Jun 23 Java/Android
浅谈自定义校验注解ConstraintValidator
Jun 30 Java/Android
Java中多线程下载图片并压缩能提高效率吗
Jul 01 Java/Android
Java移除无效括号的方法实现
Aug 07 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
Java十分钟精通进阶适配器模式
Apr 06 Java/Android
Java 超详细讲解ThreadLocal类的使用
Apr 07 Java/Android
JAVA 线程池(池化技术)的实现原理
Apr 28 Java/Android
Spring Security动态权限的实现方法详解
Jun 16 Java/Android
JDK8中String的intern()方法实例详细解读
Sep 23 Java/Android
Java对文件的读写操作方法
Apr 29 #Java/Android
Java设计模式中的命令模式
Apr 28 #Java/Android
Android开发之底部导航栏的快速实现
Apr 28 #Java/Android
Java8 CompletableFuture 异步回调
Apr 28 #Java/Android
Springboot-cli 开发脚手架,权限认证,附demo演示
Apr 28 #Java/Android
Java 异步任务计算FutureTask
Apr 28 #Java/Android
带你了解Java中的ForkJoin
You might like
php cache类代码(php数据缓存类)
2010/04/15 PHP
workerman结合laravel开发在线聊天应用的示例代码
2018/10/30 PHP
js自定义事件及事件交互原理概述(一)
2013/02/01 Javascript
Jquery实现列表(隔行换色,全选,鼠标滑过当前行)效果实例
2013/06/09 Javascript
jQuery中queue()方法用法实例
2014/12/29 Javascript
javascript日期格式化方法汇总
2015/10/04 Javascript
基于javascript实现漂亮的页面过渡动画效果附源码下载
2015/10/26 Javascript
基于Node.js的强大爬虫 能直接发布抓取的文章哦
2016/01/10 Javascript
jQuery 获取页面li数组并删除不在数组中的key
2016/08/02 Javascript
jquery中用函数来设置css样式
2016/12/22 Javascript
ES6新特性之变量和字符串用法示例
2017/04/01 Javascript
JavaScript中三个等号和两个等号你了解多少
2017/07/04 Javascript
jQuery实现的简单歌词滚动功能示例
2019/01/07 jQuery
js实现全选和全不选
2020/07/28 Javascript
jquery简易手风琴插件的封装
2020/10/13 jQuery
Python的条件语句与运算符优先级详解
2015/10/13 Python
Python解析最简单的验证码
2016/01/07 Python
Python用sndhdr模块识别音频格式详解
2018/01/11 Python
使用python将图片按标签分入不同文件夹的方法
2018/12/08 Python
在python中对变量判断是否为None的三种方法总结
2019/01/23 Python
python之pyqt5通过按钮改变Label的背景颜色方法
2019/06/13 Python
python实现单链表的方法示例
2019/09/03 Python
python绘制雪景图
2019/12/16 Python
pandas分组聚合详解
2020/04/10 Python
Python 中Operator模块的使用
2021/01/30 Python
利用css3画个同心圆示例代码
2017/07/03 HTML / CSS
如何使用PHP session
2015/04/21 面试题
如何用Java实现列出某个目录下的所有子目录
2015/07/20 面试题
法律专业实习鉴定
2013/12/22 职场文书
建筑安全标语
2014/06/07 职场文书
2014机关党员干部“正风肃纪”思想汇报
2014/09/15 职场文书
信息合作协议书
2014/10/09 职场文书
2014年医生工作总结
2014/11/21 职场文书
介绍信范文
2015/01/31 职场文书
电影建党伟业观后感
2015/06/01 职场文书
股东协议书范本2016
2016/03/21 职场文书