Object和Set小结

本文总结了Java中Object类的基本方法,包括toString()、equals()和hashCode(),强调了equals()的重写以及instanceOf关键字在判断数据类型时的作用。此外,还探讨了Set集合的无序、不重复的特性,解释了哈希表和TreeSet的存储方式,提到了Comparable接口和Comparator接口在排序中的应用。
摘要由CSDN通过智能技术生成

Object

1.基础

Java中所有类的基类!!!
Java中所有的类都是间接或者直接继承Object类。
Object类的引用数据类型变量可以保存Java中任意数据类型空间的首   地址。

Object类内规定了一些方法:
String toString();

	当前对象建议String类型描述。默认情况是当前类所属包名.类名@十六进制内存地址
	如果对于数据类型展示有要求,可以重写toString方法,在展示的方法中会默认执行
	toString方法
int hashCode();
	内存中当前对象的唯一索引值,默认情况下是当前对象所处空间首地址的十进制展示。
boolean equals(Object obj);
	比较方法,判断两个对象是否一致,Object类内默认情况下比较的方式是地址比较。
	两个对象地址一致,表示肯定是相同对象。如果我们期望修改equals比较规则,可以
	在当前类内重写
	【注意】
    	Java中规定,如果两个对象的equals比较方法结果为true,要求hashCode值必须
    	一致

线程有关方法
void wait();
void notify();
void notifyAll();

反射有关方法

2.equals方法

比较两个对象是否一致,在Object类内默认方式是比较两个对象的地址是否一致。

代码中存在一些情况,需要比较的是两个对象中保存的内容是一直,但是使用Object类内继承而来的equals方法,是不合理的!!!

方法的重写

  1. 判断两个对象是不是同一个对象。如果调用方法的类对象和传入参数类对象
  2. 地址一致,那就是同一个对象,返回true,搞定!!!
  3. equals方法参数是Object类型,那也就是说任何类型的数据都可以作为参数。
  4. 两个数据类型不一致,是否需要进行比较操作。
  5. 判断数据类型是否一致
  6. 使用关键字 instanceOf,同数据类型继续运行,非同类型,结束判断返回false
  •  格式:                                                          
     类对象 instanceOf 类名                                        
     判断对象中保存的数据                                                
     Student中我们比较id, name, age, gender就可以了                    
    

3.hashCode方法

返回的内容是当前对象的空间首地址十进制展示方式。

hashCode使用未进行重写的情况下,会使用地址作为hashCode对应的数据,重写之后,不再使用地址。重写之后hashCode 不对应当前对象所在地址。

Set集合

1.特征
特征:
无序,不可重复

无序:添加顺序和存储顺序不一致,【不代表有排序效果】
不可重复: 在一个Set集合中不能出现相同元素
  • 2.哈希表的存储*
	HashSet<Person> hashSet = new HashSet<Person>();
		
		Person p1 = new Person(1, "宝哥", 10);
		Person p2 = new Person(2, "大熊", 15);
		Person p3 = new Person(3, "骚磊", 2);
		Person p4 = new Person(4, "骚杰", -5);
		Person p5 = new Person(5, "林妹妹", 11);
		
		/*
		 * 当前这里两个元素,ID一样 ==> hashCode值是一致,会通过底层哈希表运算
		 * 保存到同一个单元格位置。
		 * 这里会通过equals方法,比较两个对象是否一致,来决定是否能够保存。
		 * 如果两个对象一致,无法保存。
		 * 
		 * 期望每一个哈希表单元格内保存的数据是唯一
		 */
		Person p6 = new Person(6, "康爷", 8);
		Person p7 = new Person(6, "康牙", 10);
		
		
		hashSet.add(p4);
		hashSet.add(p6);
		hashSet.add(p3);
		hashSet.add(p5);
		hashSet.add(p2);
		hashSet.add(p1);
		hashSet.add(p7);

3.TreeSet 树形存储

                没有比较方式无法存储
  1. Comparable接口使用
  interface Comparable<T> {
	int compareTo(T t);
}

方法参数为T类型,由实现类遵从接口时约束,
compareTo方法,返回值类型int类型,0, 负数,正数
0 表示两个元素一致,如果在TreeSet中比较结果为0,表示同一个元素,无法存储第二个。

Comparable接口由存储元素对应的类遵从,完成该方法

  1. Comparator接口使用
  interface Comparator<T> {
	int compare(T o1, T o2);
}

需要完成一个自定义比较器类对象,
int 返回值 0,负数,正数
0 表示两个元素一致,如果在TreeSet中比较结果为0,表示同一个元素,无法存储第二个。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值