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 相关文章推荐
Springboot集成阿里云OSS上传文件系统教程
Jun 28 Java/Android
springboot项目以jar包运行的操作方法
Jun 30 Java/Android
浅谈sql_@SelectProvider及使用注意说明
Aug 04 Java/Android
OpenCV实现普通阈值
Nov 17 Java/Android
java项目构建Gradle的使用教程
Mar 24 Java/Android
Java 垃圾回收超详细讲解记忆集和卡表
Apr 08 Java/Android
Android开发 使用文件储存的方式保存QQ密码
Apr 24 Java/Android
Android存储中最基本的文件存储方式
Apr 30 Java/Android
mybatis 获取更新记录的id
May 20 Java/Android
springboot读取nacos配置文件
May 20 Java/Android
Spring中的@Transactional的工作原理
Jun 05 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版微信公众平台实现预约提交后发送email的方法
2016/09/26 PHP
PHP实践教程之过滤、验证、转义与密码详解
2017/07/24 PHP
PHP执行普通shell命令流程解析
2020/08/24 PHP
JavaScript 设计模式 富有表现力的Javascript(一)
2010/05/26 Javascript
javascript中"/"运算符常见错误
2010/10/13 Javascript
拥抱模块化的JavaScript
2012/03/07 Javascript
node.js中的buffer.slice方法使用说明
2014/12/10 Javascript
jQuery中的jQuery()方法用法分析
2014/12/27 Javascript
jQuery实现Tab选项卡切换效果简单演示
2015/11/23 Javascript
实例详解jQuery结合GridView控件的使用方法
2016/01/04 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
2016/06/24 Javascript
javaScript事件机制兼容【详细整理】
2016/07/23 Javascript
谈谈JavaScript的New关键字
2016/08/26 Javascript
使用Webpack提高Vue.js应用的方式汇总(四种)
2017/07/10 Javascript
webpack构建react多页面应用详解
2017/09/15 Javascript
bootstrap select下拉搜索插件使用方法详解
2017/11/23 Javascript
vue项目中axios使用详解
2018/02/07 Javascript
Vue中使用的EventBus有生命周期
2018/07/12 Javascript
浅谈vue 组件中的setInterval方法和window的不同
2020/07/30 Javascript
[54:17]DOTA2-DPC中国联赛定级赛 RNG vs iG BO3第二场 1月10日
2021/03/11 DOTA
python自动安装pip
2014/04/24 Python
Python发送email的3种方法
2015/04/28 Python
使用Python简单的实现树莓派的WEB控制
2016/02/18 Python
Python实现的异步代理爬虫及代理池
2017/03/17 Python
Python语言描述最大连续子序列和
2017/12/05 Python
Window 64位下python3.6.2环境搭建图文教程
2018/09/19 Python
记录Python脚本的运行日志的方法
2019/06/05 Python
Python模块/包/库安装的六种方法及区别
2020/02/24 Python
python requests.get带header
2020/05/05 Python
Pycharm自带Git实现版本管理的方法步骤
2020/09/18 Python
HTML5学习笔记之History API
2015/02/26 HTML / CSS
大学生自荐书范文
2013/12/10 职场文书
小学班级口号
2014/06/09 职场文书
时尚女魔头观后感
2015/06/04 职场文书
单位提档介绍信
2015/10/22 职场文书
Python基础之操作MySQL数据库
2021/05/06 Python