LinkedList,Object和Set

LinkedList,Object和Set

1 LinkedList

1.1. LinkedList实现

类似于ArrayList

1.2. LinkedList特征

1. 存储数据,非连续空间。
2. 数据之间通过引用连接,方便遍历和使用
3. 遍历效率较低,数据非连续空间存储,需要通过引用跳转过程来完成
4. 删除插入操作效率高,但是注意地址的转移和保存问题。
5. LinkedList链表当中的操作其实大部分都是和C语言指针一个概念

2 Object类

2.1 Object类概述

Java中所有类的基类!!!
	Java中所有的类都是间接或者直接继承Object类。
	Object类的引用数据类型变量可以保存Java中任意数据类型空间的首地址。
Object类内规定了一些方法:
	String toString();
		如果对于数据类型展示有要求,可以重写toString方法,在展示的方法中会默认执行
		toString方法
	int hashCode();
		内存中当前对象的唯一索引值
	boolean equals(Object obj);
		比较方法,判断两个对象是否一致,Object类内默认情况下比较的方式是地址比较。
		两个对象地址一致,表示肯定是相同对象。如果我们期望修改equals比较规则,可以
		在当前类内重写 equals重写结果为true 则hashCode必须重写

2.2 toString方法

用来展示对象内容
Eclipse快捷键 Alt + Shift + S

2.3 equals方法

	比较两个对象是否一致,在Object类内默认方式是比较两个对象的地址是否一致。
	如果比较内容的话需要重写equals方法

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

2.4 hashCode方法

	在Object类内,hashCode方法,返回的内容是当前对象的空间首地址十进制展示方式。	
	当前类重写equals方法之后,两个当前类对象比较结果为true,那么要求这两个对象的hashCode必须一致!!!
	hashCode使用有一个唯一原则。
	一般会参考参与equals比较的所有成员变量来组成对应的hashCode,这里会使用到一些Java中提供的计算哈希值的方法。
	
	hashCode使用未进行重写的情况下,会使用地址作为hashCode对应的数据,重写之后,不再使用地址。重写之后hashCode 不对应当前对象所在地址。

@Override
public int hashCode() {
	// 这里通过Objects 工具类内的hash方法,传入所有参与equals比较的成员变量
	// 得到对应的hashCode值
	return Objects.hash(id, name, age, gender);
}

3.Set集合

3.1 Set集合概述

特征:
	无序,不可重复
	
	无序:添加顺序和存储顺序不一致,【不代表有排序效果】
	不可重复: 在一个Set集合中不能出现相同元素

interface Set<E> 
--| class HashSet<E> 底层是哈希表存储数据
--| class TreeSet<E> 底层存储数据是一个二叉树

3.2 HashSet

3.2.1 底层结构

		/*
		 * 如两个元素,ID一样 ==> hashCode值是一致,会通过底层哈希表运算
		 * 保存到同一个单元格位置。
		 * 这里会通过equals方法,比较两个对象是否一致,来决定是否能够保存。
		 * 如果两个对象一致,无法保存。
		 * 
		 * 期望每一个哈希表单元格内保存的数据是唯一
		 */

3.3 TreeSet

3.3.1 Tree树形结构

	平衡二叉树的方式

3.3.2 TreeSet存储方式

没有比较方式无法存储

3.3.3 Comparable接口使用

interface Comparable<T> {
	int compareTo(T t);
}

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

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

3.3.4 Comparator接口使用

interface Comparator<T> {
	int compare(T o1, T o2);
}
需要完成一个自定义比较器类对象,
	int 返回值 0,负数,正数
	0 表示两个元素一致,如果在TreeSet中比较结果为0,表示同一个元素,无法存储第二个。

3.3.5 Comparator使用要高于Comparable使用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值