集合体系之Set及其子类知识

Set(接口)

public interface Set<E>extends Collection<E>

​ 特点:无序(存储顺序与取出顺序不一致,但它有内在的存储顺序该顺序通过哈希表生成,有时在输入时可能与其内在顺序相同,但之并不代表其有序,多输入几个数据就会发现其无序性),唯一。

其方法与Collection相同,是Set集合框架的顶层接口,不做过多讲解。

HashSet(类)

public class HashSet<E>extends AbstractSet<E>
implements Set<E>, Cloneable, Serializable

HashSet实现唯一性的原理:

​ 底层代码中虽然较为复杂,但是还是可以看出其依赖了hashCode()与equals()方法;

步骤:

​1. 首先比较哈希值

(1)如果相同,继续走,比较的值值或equals()方法

​(2) 如果不同,添加到集合中

按照方法的步骤来说:

​ 1.先观察由hashCode()实现的hash()方法值是否相同

​ (1)相同:走equals()方法;

​ <1>返回true:说明元素重复,没有添加到集合中;

​ <2>返回false:说明元素不重复,以添加到集合中

​ (2)不同:就添加元素到集合

如果类没有重写这两个方法,默认使用Object。一般来说不相同;

  • HashSet的底层数据类型为哈希表(元素是链表的数组)由HsahMap实现,哈希表依赖于哈希值存储,

LinkedHashSet(类)

public class LinkedHashSet<E>extends HashSet<E>
implements Set<E>, Cloneable, Serializable

特点:底层由链表和哈希表实现,

通过链表保证元素有序性,通过哈希表实现元素唯一性。

  • 其无特殊方法,使用去父类方法操作即可

TreeSet(类)

public class TreeSet<E>extends AbstractSet<E>
implements NavigableSet<E>, Cloneable, Serializable

特点:能够按照某种规则对元素排序

排序有两种方式:

1.自然排序

​ TreeSet默认自然排序

​ 如果一个自定义对象要实现自然排序,就必须实现Comparable接口

2.比较器排序

​ 在声明对象时使用带参构造选择构造器,用匿名内部类实现比较器

如果自然排序和比较器排序同时存在优先使用比较器排序

TreeSet集合保证元素排序和唯一性的原理:

唯一性:根据返回值是否为0来决定。

排序:

​ 1.自然排序(元素具备比较性)

​ 让元素所属的类实现自然排序接口Comparable

​ 2.比较器排序(集合具备比较性)

​ 让集合的构造方法接收一个比较器的子类对象Comparator

两种排序实例:

  • 自然排序
import java.util.TreeSet;

//通过泛型来约束Compareable的比较类型
class Student implements Comparable<Student>{
private int age;
private String name; Student (String name,int age){
this.age = age;
this.name = name;
} @Override
public String toString() {
return "Student{" +
"age=" + age +
", name='" + name + '\'' +
'}';
} @Override
public int compareTo(Student s) {
//此处只是判断了年龄的条件,但是除了年龄外还有姓名不相同
// 但年龄相同的元素被去掉了,所以还要判断年龄是否相同
//而在此处需要判断所有元素是否相同,比较时基本元素直接比较,
//比较引用类型时比较它们基本类型
// return this.age - s.age;
int mun = this.age - s.age;
return mun == 0?this.name.compareTo(s.name):mun;
}
} public class treeset的自然排序 {
public static void main(String[] args) {
Student s1 = new Student("aa",34);
Student s2 = new Student("bb",24);
Student s3 = new Student("cc",32);
Student s4 = new Student("dd",36);
Student s5 = new Student("ee",36);
TreeSet<Student> h = new TreeSet<>();
h.add(s1);
h.add(s2);
h.add(s3);
h.add(s4);
h.add(s5);
System.out.println(h);
}
}
  • 比较器排序
import java.util.Comparator;
import java.util.TreeSet; class Person {
private int age;
private String name; Person (String name,int age){
this.age = age;
this.name = name;
} @Override
public String toString() {
return "Student{" +
"age=" + age +
", name='" + name + '\'' +
'}';
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
}
} public class tree的比较器排序 {
public static void main(String[] args) { TreeSet<Person> ts = new TreeSet<>(new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
int num = o1.getAge() - o2.getAge();
return num == 0?o1.getName().compareTo(o2.getName()):num;
}
}); Person p1 = new Person("aa",2);
Person p2 = new Person("bb",3);
Person p3 = new Person("cc",4);
Person p4 = new Person("dd",1);
Person p5 = new Person("ee",2);
Person p6 = new Person("aa",2); ts.add(p1);
ts.add(p2);
ts.add(p3);
ts.add(p4);
ts.add(p5);
ts.add(p6); for (Person p:ts){
System.out.println(p.getName()+"====="+p.getAge());
}
}
}

两种排序自然排序适合多次进行排序时使用,而比较器排序适合排序次数不多的情况。而且如果先实现了自然排序,再修改了类的属性则重写的自然排序也要进行修改。但是比较器排序没有这样的问题,因为其在使用时才会被重写。

Javase之集合体系(3)之Set及其子类知识的更多相关文章

  1. Javase之集合体系(4)之Map集合

    集合体系之Map集合 ##Map<K,V>( 接口 ) 特点:将键映射到值对象,一个映射不能包含重复的键:每个键只能映射一个值 Map集合与Collection集合的区别 ​ Map集合存 ...

  2. Javase之集合体系(2)之List及其子类ArrayList,LinkedList与Vector及其迭代器知识

    集合体系之List及其子类ArrayList,LinkedList与Vector及其迭代器知识 List(接口) 特点:有序(存储与取出顺序相同),可重复 List子类特点: ​ ArrayList: ...

  3. Javase之集合体系之(1)集合顶层类Collection与其迭代器知识

    集合体系之集合顶层类Collection与其迭代器知识 集合的由来:Java是一门面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,就必须把多个对象进行存储,而要存 ...

  4. javaSE中级篇3——集合体系(另外一种存储容器)——更新完毕

    集合还是一种工具,所以它们的包都在java.util包下 1.集合的整个体系结构(是需要掌握的体系,完全体系不是这样) 对图中所说的 序和重复 这两词的说明: 序:指的是添加进去的元素和取出来的元素 ...

  5. 浅谈Java的集合体系

    集合体系框架图 集合接口 Java集合类库将接口(interface)与实现(implementation)分离,如上图,Set是一个集合接口,而HashSet与TreeSet都是实现了Set接口的子 ...

  6. JAVA提高九:集合体系

    在经过了前面的JDK6.0新特性的学习后,将进一步深入学习JDK,因为集合的重要性,因此从集合开始入手分析: 一.集合概况 Java是一种面向对象语言,如果我们要针对多个对象进行操作,那么首先必要将多 ...

  7. Java集合中List,Set以及Map等集合体系详解

    转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...

  8. Java集合体系总结

    一.集合框架 集合是容纳数据的容器,java常用的集合体系图如下.以集合中是否运行重复元素来分,主要有List和Set接口,List集合中可以有重复元素,Set集合集合中的元素不可重复,Iterato ...

  9. 大数据之路week02 Collection 集合体系收尾(Set)

    1.Set集合(理解) (1)Set集合的特点 无序,唯一. (2)HashSet集合(掌握) A: 底层数据结构是哈希表(是一个元素为链表的数组) B: 哈希表底层依赖两个方法: hashCode( ...

随机推荐

  1. 手把手教你制作Jlink-OB调试器(含原理图、PCB、外壳、固件)

    前言 好久没更新博客和公众号了,感谢大家还没取关哈,好吧,我承认是我太懒了,今天分享一个福利! 趁着前段时间嘉立创和捷配打价格战,一天之内,多次降价,看着真是热闹.捷配降到最低3元一款,而嘉立创降到最 ...

  2. kafka速度快的原因

    我们都知道Kafka非常快,比绝大多数的市场上其他消息中间件都要快.这里来研究下那么为什么Kafka那么快(当然不会是因为它用了Scala). Kafka的消息是保存或缓存在磁盘上的,一般认为在磁盘上 ...

  3. SpringBoot2.0 整合 SpringSecurity 框架,实现用户权限安全管理

    本文源码:GitHub·点这里 || GitEE·点这里 一.Security简介 1.基础概念 Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方 ...

  4. mysql的repeat()函数

    用来复制字符串,如下'ab'表示要复制的字符串,2表示复制的份数 mysql> select repeat('ab',2); +----------------+ | repeat('ab',2 ...

  5. 通俗易懂,什么是.NET/.NET Framework/.NET Core/.Net Standard?

    什么是.NET?什么是.NET Framework?本文将从上往下,循序渐进的介绍一系列相关.NET的概念,先从类型系统开始讲起,我将通过跨语言操作这个例子来逐渐引入一系列.NET的相关概念,这主要包 ...

  6. Ajax跨域请求,设置content

    在使用Ajax跨域请求时,如果设置Header的ContentType为application/json,会分两次发送请求.第 一次先发送Method为OPTIONS的请求到服务器,这个请求会询问服务 ...

  7. jQuery从零开始(二)

    1.css类的操作 -----addClass() 向被选元素添加一个或者多个类 -----removeClass() 删除被选元素的类 -----toggleClass() 取反 -----css( ...

  8. flutter全栈开发学习资料大全 免费flutter学习视频 文字教程!

    flutter今年特别火,google推出flutter就是为了一次开发全平台应用,包括PC端,手机wap端,android,ios直接生成APP应用,如果真的能像谷歌说的,那我们开发人员就真的好好学 ...

  9. Codeforces Round #603 (Div. 2) A. Sweet Problem 水题

    A. Sweet Problem the first pile contains only red candies and there are r candies in it, the second ...

  10. Wireshark 抓取USB的数据包

    需要使用root权限来运行Wireshark,并利用Wireshark来嗅探USB通信数据.当然了,我们并不建议大家利用root权限来进行操作.我们可以使用Linux提供的usbmon来为我们获取和导 ...