Set常用子类特点
HashSet: 重写 hashCode和equals方法
特点:无序,唯一
底层结构是:
哈希表:元素为链表的数组。综合了链表和数组的好处
add方法:底层实际是依赖于HashCode()和equals()方法
HashSet实际用的是HashMap
public HashSet() {
map = new HashMap<>();
}
案例-HashSet存储自定义对象
出现问题:
重复的元素也被添加了,不能保证元素唯一性
原因:自定义类没有重写HashCode和equals方法;
分析:
(1) 默认继承Object类的HashCode和equals方法,而Object的HashCode值是通过对象
的内部地址值转换为一个整数得到的,不同的对象的地址值不同,进而可以知道转换后
的HashCode值也不可能相同。HashCode值不同就当作不是重复的元素而添加了。
(2)equals方法默认也是比较地址值,如果不重写equals方法,那么不同的对象
比较的结果也一定就是false;将会当作不是重复元素而添加了
解决:重写自定义类的HashCode和equals方法
思考:重写HashCode(),那么HashCode值跟什么有关系呢?
答: 和对象的成员变量值有关系
重写HashCode方法:
就将对象的成员变量值相加:
基本类型:直接相加
引用类型:就加哈希值
// return name.hashCode()+age;
// 代码优化如下
return name.hashCode()+age*31;
注意:判断是否是重复元素步骤:
1-先比较HashCode值:
1-1:如果HashCode值不同:直接添加
1-2:如果HashCode值相同:
1-2-1:继续判断equals方法:
返回false:添加元素
返回true:放弃添加
对于hashCode和equals方法的理解:(新华字典: 即使是在同一页了,也有可能不是同一个元素)
同一页:hashCode值
同一页中同一个元素:hashCode值相同情况下,还要继续采用equals方法判断
二、LinkedHashSet:
底层数据结构是:链表和哈希表
链表保证元素有序
哈希表保证元素唯一
三、TreeSet:
(1)实现Comparable自然排序接口,重写compareTo方法
(2)实现Comparator比较器排序接口,重写compare方法
排序方式:以构造函数确定排序方式
A 无参构造:自然排序
class Student implements Comparable<Student>{
@Override
public int compareTo(Student s){
//按年龄排序
int num=this.age-s.age;
//隐含条件,年龄相同时,应该继续比较姓名
int num2=num==0?this.name.compareTo(s.name):num;
return num2;
}
}
B 有参构造:比较器排序 将自定义的比较器类对象作为构造方法的参数
class MyComparator implements Comparator<Student>{
@Override
public int compare(Student s1,Student s2){
int num=(int)(stu2.getTotal()-stu1.getTotal());
int num2=num==0?stu1.getName().compareTo(stu2.getName()):num;
return num2;
}
}
TreeSet<Student> ts=new TreeSet<Student>(new MyComparator());
---------------------------------------------
字符串的比较
int compareTo(String str):
Set常用子类特点的更多相关文章
- 集合中Set接口与Collection接口,常用子类TreeSet,HashSet.
Set接口与List接口的不同之处在于: 不允许有重复的数据. 定义如下: public interface Set<E>extends Collection<E> 主要方法与 ...
- Set 接口常用子类及其特点
Set 集合中元素不可重复,是无序的(存入和取出的顺序是不一样的), Set 接口中的方法和 Collection 接口一致. 常用子类: HashSet : 内部数据结构是哈希表, 是不同步的 Li ...
- List 接口常用子类及其特点
List 常用子类: - Vector: 内部是数组数据结构,是同步的. 增删, 查询都很慢 - ArrayList: 内部是数组数据结构,是不同步的,替代了 Vector,不同步的效率较高. 特点: ...
- Map集合,Map常用子类
Map 集合 1,Collection中的集合,元素是孤立的,向季和忠储存的元素采用一个元素方式储存 2,Map中的集合,元素是成对存在的,每个元素中的集合称为双列集合 3,Collection中的集 ...
- Map集合概述和Map常用子类
概述java.util.Map接口 Map<K,V> 有两个泛型 类型参数:K - 此映射所维护的键的类型V - 映射值的类型 特点:1.Map集合是双列集合,一个元素包含两个值,一个是k ...
- Map集合和Map常用子类
Map集合 java.util.Map<K,V>集合 Map集合的特点: 1.Map集合是一个双列集合,一个元素包含两个值(Key,Value) 2.Map集合中的元素,key和value ...
- 系统学习 Java IO (十三)----字符读写 Reader/Writer 及其常用子类
目录:系统学习 Java IO---- 目录,概览 Reader Reader 类是 Java IO API 中所有 Reader 子类的基类. Reader 类似于 InputStream ,除了它 ...
- 阶段1 语言基础+高级_1-3-Java语言高级_04-集合_08 Map集合_2_Map常用子类
常用的实现类HashMap 它的子类.LinkedHaspMap
- 17、Map接口及其常用子类(Hashtable、HashMap、WeakHashMap)
17.Map接口 Map没有继承Collection接口,Map提供key到value的映射.一个Map中不能包含相同的key,每个key只能映射一个value.Map接口提供3种集合的视图,Map的 ...
随机推荐
- Python之 context manager
在context manager中,必须要介绍两个概念: with as... , 和 enter , exit. 下文将先介绍with语句,然后介绍 __enter__和exit, 最后介绍cont ...
- poj1056
简单题 #include <iostream> #include <string> using namespace std; struct cnode { cnode *pze ...
- 16 Go Concurrency Patterns: Timing out, moving on GO并发模式: 超时, 继续前进
Go Concurrency Patterns: Timing out, moving on GO并发模式: 超时, 继续前进 23 September 2010 Concurrent progra ...
- supervisor管理uwsgi
1. 前言 传统的管理uwsgi服务: 1. 通过shell脚本来编写start restart stop函数来控制 2. 比较麻烦,有时候控制写的烂,还会出现意想不到的错误 supervisor进行 ...
- VMware虚拟机的三种联网方法及原理(转)
转自:http://blog.chinaunix.net/uid-24876683-id-3593774.html 一.Brigde——桥接 :默认使用VMnet0 .原理: Bridge 桥&quo ...
- 20165333 预备作业3 Linux安装及学习
预备作业3 Linux安装及学习 Linux系统安装 在老师的教程帮助下成功的完成了虚拟机的安装,但安装过程中也遇到了一些问题.在下载ubuntu时,总是下载失败,在求助同学后,在中文版官网的网址,才 ...
- php取得当前时间函数
php取得当前时间函数文章提供了php的几种获取当前时间的函数,date,time等哦,同时告诉我如何解决时区问题哦. php获取当前时间 使用函式 date() 实现 <?php echo $ ...
- Centos 常用命令[持续积累中...]
CentOS常用到的查看系统命令 uname -a cat /etc/issue /sbin/ifconfig # 查看内核/操作系统/CPU信息 head -n 1 /etc/issue # 查看操 ...
- Factroy 简单工厂
意图 定义一个用于创建对象的接口,让子类决定实例化哪一个类. Factory Method使一个类的实例化延迟到其子类. 动机 框架使用抽象类定义和维护对象之间的关系.这些对象的创建通常也由框架负责. ...
- loadrunner 的Administration Page里面设置
loadrunner 的Administration Page里面设置 1.Set LOGIN form's action tag to an error page.在登录的时候,传递一个动态变量 ...