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 18 Java/Android
实体类或对象序列化时,忽略为空属性的操作
Jun 30 Java/Android
Java并发编程必备之Future机制
Jun 30 Java/Android
spring cloud gateway中如何读取请求参数
Jul 15 Java/Android
关于@OnetoMany关系映射的排序问题,使用注解@OrderBy
Dec 06 Java/Android
maven依赖的version声明控制方式
Jan 18 Java/Android
springboot入门 之profile设置方式
Apr 04 Java/Android
Java Lambda表达式常用的函数式接口
Apr 07 Java/Android
Spring Boot项目如何优雅实现Excel导入与导出功能
Jun 10 Java/Android
Java完整实现记事本代码
Jun 16 Java/Android
java实现web实时消息推送的七种方案
Jul 23 Java/Android
Android移动应用开发指南之六种布局详解
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
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
一键生成各种尺寸Icon的php脚本(实例)
2017/02/08 PHP
php将html转为图片的实现方法
2017/05/19 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
2017/11/17 PHP
php微信公众号开发之欢迎老朋友
2018/10/20 PHP
PHP7 其他语言层面的修改
2021/03/09 PHP
javascript options属性集合操作代码
2009/12/28 Javascript
jquery div拖动效果示例代码
2013/12/08 Javascript
javascript中2个感叹号的用法实例详解
2014/09/04 Javascript
js阻止默认浏览器行为与冒泡行为的实现代码
2016/05/15 Javascript
基于BootStrap与jQuery.validate实现表单提交校验功能
2016/12/22 Javascript
简单实现nodejs上传功能
2017/01/14 NodeJs
vue使用watch 观察路由变化,重新获取内容
2017/03/08 Javascript
jQuery鼠标移动图片上实现放大效果
2017/06/25 jQuery
详解Angular操作cookies方法
2018/06/01 Javascript
详解ES6 系列之异步处理实战
2018/10/26 Javascript
webpack结合express实现自动刷新的方法
2019/05/07 Javascript
[01:45]绝对公平!DOTA2队长征召模式详解
2014/04/25 DOTA
python自动格式化json文件的方法
2015/03/11 Python
举例讲解Python面向对象编程中类的继承
2016/06/17 Python
Python进阶:生成器 懒人版本的迭代器详解
2019/06/29 Python
python点击鼠标获取坐标(Graphics)
2019/08/10 Python
python 实现多维数组(array)排序
2020/02/28 Python
naturalizer加拿大官网:美国娜然女鞋
2017/04/04 全球购物
使用索引有什么好处
2016/07/27 面试题
毕业求职自荐信格式是什么
2013/11/19 职场文书
找工作最新求职信
2013/12/22 职场文书
《尊严》教学反思
2014/02/11 职场文书
幼儿园元旦亲子活动方案
2014/02/17 职场文书
纪念九一八事变演讲稿:牢记九一八,屈辱怎能忘
2014/09/14 职场文书
淘宝好评语句大全
2014/12/31 职场文书
周年庆典答谢词
2015/01/20 职场文书
兼职安全员岗位职责
2015/02/15 职场文书
高三语文教学反思
2016/02/16 职场文书
mysql字符串截取函数小结
2021/04/05 MySQL
Vue2.0搭建脚手架
2022/03/13 Vue.js