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
解决tk mapper 通用mapper的bug问题
Jun 16 Java/Android
详解Java实践之适配器模式
Jun 18 Java/Android
详解Java实现数据结构之并查集
Jun 23 Java/Android
Java多条件判断场景中规则执行器的设计
Jun 26 Java/Android
浅谈resultMap的用法及关联结果集映射
Jun 30 Java/Android
JavaWeb 入门篇(3)ServletContext 详解 具体应用
Jul 16 Java/Android
SpringBoot整合Mybatis Generator自动生成代码
Aug 23 Java/Android
spring cloud 配置中心native配置方式
Sep 25 Java/Android
Java如何实现通过键盘输入一个数组
Feb 15 Java/Android
Elasticsearch 配置详解
Apr 19 Java/Android
Android开发 使用文件储存的方式保存QQ密码
Apr 24 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
THINKPHP+JS实现缩放图片式截图的实现
2010/03/07 PHP
JavaScript入门教程 Cookies
2009/01/31 Javascript
简介JavaScript中substring()方法的使用
2015/06/06 Javascript
JSON与XML的区别对比及案例应用
2016/11/11 Javascript
概述如何实现一个简单的浏览器端js模块加载器
2016/12/07 Javascript
jquery利用json实现页面之间传值的实例解析
2016/12/12 Javascript
JavaScript三种绑定事件方式及相互之间的区别分析
2017/01/10 Javascript
javascript实现右下角广告框效果
2017/02/01 Javascript
JS排序之选择排序详解
2017/04/08 Javascript
微信小程序页面滑动屏幕加载数据效果
2020/11/16 Javascript
jQuery+koa2实现简单的Ajax请求的示例
2018/03/06 jQuery
JS实现DOM节点插入操作之子节点与兄弟节点插入操作示例
2018/07/30 Javascript
js时间戳转yyyy-MM-dd HH-mm-ss工具类详解
2019/04/30 Javascript
Vue.js组件实现选项卡以及切换特效
2019/07/24 Javascript
vue路由 遍历生成复数router-link的例子
2019/10/30 Javascript
[02:46]2014DOTA2国际邀请赛 选手为你解读比赛MVP充满梦想
2014/07/09 DOTA
Python的Bottle框架中返回静态文件和JSON对象的方法
2015/04/30 Python
Python实现Linux命令xxd -i功能
2016/03/06 Python
Python使用numpy模块实现矩阵和列表的连接操作方法
2019/06/26 Python
详解基于python的多张不同宽高图片拼接成大图
2019/09/26 Python
使用python 对验证码图片进行降噪处理
2019/12/18 Python
Python使用进程Process模块管理资源
2020/03/05 Python
简单了解如何封装自己的Python包
2020/07/08 Python
python实现网页录音效果
2020/10/26 Python
CSS3效果:自定义“W”形运行轨迹实例
2017/03/29 HTML / CSS
HTML5 body设置全屏背景图片的示例代码
2020/12/08 HTML / CSS
美国电视购物:QVC
2017/02/06 全球购物
国际旅客访问北美最大的汽车租赁提供商:Alamo Rent A Car
2018/06/13 全球购物
加拿大户外探险购物网站:SAIL
2020/06/27 全球购物
电气技术员岗位职责
2013/11/19 职场文书
化妆品促销方案
2014/02/24 职场文书
少先队学雷锋活动总结范文
2014/03/09 职场文书
简易离婚协议书(范本)
2014/10/25 职场文书
工作期间打牌检讨书范文
2014/11/20 职场文书
2015年秋季学校开学标语
2015/07/16 职场文书
排查并解决Oracle sysaux表空间异常增长
2022/04/20 Oracle