java集合框架(hashSet自定义元素是否相同,重写hashCode和equals方法)

/*HashSet 基本操作
* --set:元素是无序的,存入和取出顺序不一致,元素不可以重复
* (通过哈希值来判断是否是同一个对象)
* ----HashSet:底层数据结构是哈希表,
* 保证数据唯一性的方法是调用存入元素的hashCode()方法
* 和equals(Object obj)方法
* HashCode值相同,才会调用equals方法
*
* */

 1 import java.util.HashSet;
 2 import java.util.Iterator;
 3 public class StudentCode {
 4
 5     public static void main(String []args){
 6         //定义HashSet,并添加数据
 7         HashSet hs=new HashSet();
 8         hs.add(new Person("lisi",11));
 9         hs.add(new Person("zhangsan",22));
10         hs.add(new Person("lisi",22));
11         hs.add(new Person("lisi",11));
12         //遍历数据(在用迭代器输出数据时,只能用迭代器进行数据操作:增删改查,不可用对象进行操作)
13         for(Iterator it=hs.iterator();it.hasNext();){
14             Person p=(Person)it.next();
15             System.out.println("姓名:"+p.getName()+",年龄:"+p.getAge());
16         }
17     }
18 }
19 class Person{
20     private String name;
21     private int age;
22     Person(String name,int age){
23         this.name=name;
24         this.age=age;
25     }
26     public String getName(){
27         return this.name;
28     }
29     public int getAge(){
30         return this.age;
31     }
32     //重写hashCode()方法,返回一个固定的哈希值
33     public int hashCode(){
34         return 60;
35     }
36     //重写equals(Object obj)方法,定义所需要的变量比较
37     public boolean equals(Object obj){
38         //判断传入的Obj是否是由Person下转型的变量
39         if(!(obj instanceof Person))
40             return false;
41         //对传入对象上转型为Person对象
42         Person p=(Person)obj;
43         //判断两个对象是否名字和年龄相等,相等则认为是同一个对象
44         return this.name.equals(p.getName())&&this.age==p.getAge();
45     }
46 }
时间: 2024-08-02 05:33:52

java集合框架(hashSet自定义元素是否相同,重写hashCode和equals方法)的相关文章

Java集合框架实现自定义排序

Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优化. 一 .使用Arrays对数组进行排序 Java API对Arrays类的说明是:此类包含用来操作数组(比如排序和搜索)的各种方法. 1.使用Arrays排序:Arrays使用非常简单,直接调用sort()即可 int[] arr = new int[] {5,8,-2,0,10}; Array

HashMap中使用自定义类作为Key时,为何要重写HashCode和Equals方法

之前一直不是很理解为什么要重写HashCode和Equals方法,才只能作为键值存储在HashMap中.通过下文,可以一探究竟. 首先,如果我们直接用以下的Person类作为键,存入HashMap中,会发生发生什么情况呢? public class Person { private String id; public Person(String id) { this.id = id; } } import java.util.HashMap; public class Main { public

java 集合框架-HashSet

/* 利用HashSet来存储自定义元素 HashSet集合保证元素唯一性的依据: 是通过两个方法,hashCode和equals来完成. 如果元素的HashCode值相同,才会判断equals是否为true. 如果元素的HashCode值不同,不会调用equals. 这两个方法都是HashSet调用的,并没有显式调用. 注意:对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法. */ import java.util.*; class Person {

Java集合框架中的元素

之前有一篇笔记,讲的是集合和泛型,这几天看Java集合中几个接口的文档,思绪非常混乱,直到看到Oracle的"The Collections Framwork"的页面,条理才清晰些,现在进行整理. 一.为什么需要集合? 应用程序中经常需要创建很多的对象来完成一定的工作,所以我们需要将这些一定数目的对象组织起来进行统一管理. 对象数组能够满足我们,如果对象的数目是清晰有限且生命周期可知,那么使用对象数组来进行管理是非常简单和直观的. 数组一旦创建,它的容量便固定了,在它的生命周期里再也无

Java自学-集合框架 HashSet

Java集合框架 HashSet 示例 1 : 元素不能重复 Set中的元素,不能重复 package collection; import java.util.HashSet; public class TestCollection { public static void main(String[] args) { HashSet<String> names = new HashSet<String>(); names.add("gareen"); Syst

[转载] Java集合框架之小结

转载自http://jiangzhengjun.iteye.com/blog/553191 1.Java容器类库的简化图,下面是集合类库更加完备的图.包括抽象类和遗留构件(不包括Queue的实现): 2.ArrayList初始化时不可指定容量,如果以new ArrayList()方式创建时,初始容量为10个:如果以new ArrayList(Collection c)初始化时,容量为c.size()*1.1,即增加10%的容量:当向ArrayList中添加一个元素时,先进行容器的容量调整,如果容

黑马程序员——java集合框架之List,Set

集合框架  1.数组与集合的不同    数组长度是固定的,集合长度是可变的    数组中可以存储基本数据类型,集合只存储对象    集合可以存储不同类型的对象        2.java集合类中有两个顶层接口Collection和Map,下面是对Collection的一些总结: 集合中常用方法:     add方法的参数类型为Object,以便于接受任意类型的对象     集合中存储的都是对象的引用(或者说地址) 迭代器是集合取出元素的方式,此方法是定义在集合的内部,这样取出方式就可以直接访问集

浅入深出之Java集合框架(下)

Java中的集合框架(下) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,哈哈这篇其实也还是基础,惊不惊喜意不意外 ̄▽ ̄ 写文真的好累,懒得写了.. 温馨提醒:建议从(上)开始看哦~ 目 录 浅入深出之Java集合框架(上) 浅入深出之Java集合框架(中)   浅入深出之Java集合框架(下) 前 言 在<浅入深出之Java集合框架(中) >中介绍了Map接口的基本操作.使用的示例是在<浅入深出之Java集合框架(上)>中的模拟学

Java集合框架(三)day_17

17.集合框架(HashSet存储字符串并遍历) A:Set集合概述及特点 通过API查看即可 B:案例演示 HashSet存储字符串并遍历 public class Demo1_HashSet { /** * @param args * Set集合,无索引,不可以重复,无序(存取不一致) */ public static void main(String[] args) { //demo1(); HashSet<Person> hs = new HashSet<>(); hs.a