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 相关文章推荐
总结一些Java常用的加密算法
Jun 11 Java/Android
Java内存模型之happens-before概念详解
Jun 13 Java/Android
浅谈什么是SpringBoot异常处理自动配置的原理
Jun 21 Java/Android
jackson json序列化实现首字母大写,第二个字母需小写
Jun 29 Java/Android
springboot临时文件存储目录配置方式
Jul 01 Java/Android
详细了解MVC+proxy
Jul 09 Java/Android
springboot中rabbitmq实现消息可靠性机制详解
Sep 25 Java/Android
Spring Boot接口定义和全局异常统一处理
Apr 20 Java/Android
Java中Dijkstra(迪杰斯特拉)算法
May 20 Java/Android
Android Canvas绘制文字横纵向对齐
Jun 05 Java/Android
Spring Boot 的创建和运行示例代码详解
Jul 23 Java/Android
Spring boot实现上传文件到本地服务器
Aug 14 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一些服务器端特性的配置加强php的安全
2006/10/09 PHP
ThinkPHP权限认证Auth实例详解
2014/07/22 PHP
php对象在内存中的存在形式分析
2015/02/03 PHP
PHP中让json_encode不自动转义斜杠“/”的方法
2017/02/28 PHP
详解PHP函数 strip_tags 处理字符串缺陷bug
2017/06/11 PHP
ASP中用Join和Array,可以加快字符连接速度的代码
2007/08/22 Javascript
jquery实现的元素的left增加N像素 鼠标移开会慢慢的移动到原来的位置
2010/03/21 Javascript
js使用函数绑定技术改变事件处理程序的作用域
2011/12/26 Javascript
JS完成代码前最好对其做5件事
2013/04/07 Javascript
Jquery节点遍历next与nextAll方法使用示例
2014/07/22 Javascript
jQuery链式调用与show知识浅析
2016/05/11 Javascript
js实现上传文件添加和删除文件选择框
2016/10/24 Javascript
JS常见疑难点分析之match,charAt,charCodeAt,map,search用法分析
2016/12/25 Javascript
JavaScript"模拟事件"的注意要点详解
2019/02/13 Javascript
如何使用50行javaScript代码实现简单版的call,apply,bind
2019/08/14 Javascript
react实现同页面三级跳转路由布局
2019/09/26 Javascript
Vue实现点击按钮复制文本内容的例子
2019/11/09 Javascript
VUE使用axios调用后台API接口的方法
2020/08/03 Javascript
Vue通过阿里云oss的url连接直接下载文件并修改文件名的方法
2020/12/25 Vue.js
Element el-button 按钮组件的使用详解
2021/02/01 Javascript
[01:06]DOTA2小知识课堂 Ep.02 吹风竟可解梦境缠绕
2019/12/05 DOTA
[00:59]DOTA2背景故事第二期之四大基本法则
2020/07/07 DOTA
跟老齐学Python之折腾一下目录
2014/10/24 Python
python实现文件快照加密保护的方法
2015/06/30 Python
Ubuntu 下 vim 搭建python 环境 配置
2017/06/12 Python
python标准库os库的函数介绍
2020/02/12 Python
领先的钻石和订婚戒指零售商:Diamonds-USA
2016/12/11 全球购物
阿姆斯特丹城市卡:Amsterdam Pass
2019/12/01 全球购物
中东最大的在线宠物店:Dubai Pet Food
2020/06/11 全球购物
最新会计专业求职信范文
2014/01/28 职场文书
初中同学聚会感言
2014/02/11 职场文书
元旦促销方案
2014/03/15 职场文书
局火灾防控工作方案
2014/05/25 职场文书
中学生民族团结演讲稿
2014/08/27 职场文书
2014年学生会工作总结
2014/11/07 职场文书
单独二胎证明
2015/06/24 职场文书