Java中的Set集合和Hash值和TreeSet的使用

2024-04-28 16:52
文章标签 java 使用 set 集合 hash treeset

本文主要是介绍Java中的Set集合和Hash值和TreeSet的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Set集合的特点

不包含重复元素的集合

没有带索引的方法,所以不能使用普通for循环遍历

HashSet对集合的迭代顺序不作任何保证

Set集合的遍历

有两种方式遍历一种是迭代器一种是增强for

package dayhou40.day49;
​
import java.util.HashSet;
import java.util.Set;
​
public class SetTest {public static void main(String[] args) {Set<String> set = new HashSet<>();set.add("hello");set.add("hi");set.add("hello");set.add("last");for (String s : set) {System.out.println(s);}}
}
​

Set集合没有什么 特殊的功能需要我们学习它的功能全部来自Collection集合

哈希值

哈希值:是根据jdk对象的地址或者字符或者数字算出来的的int类型的数值

Object对象中的public int hashCode:返回对象的哈希码值

package dayhou40.day50;
​
public class student {private String name;private int age;
​public student(String name, int age) {this.name = name;this.age = age;}
​public student() {}
​public String getName() {return name;}
​public void setName(String name) {this.name = name;}
​public int getAge() {return age;}
​public void setAge(int age) {this.age = age;}
}
​
package dayhou40.day50;
​
public class hashCodeTest {public static void main(String[] args) {student s1 = new student("张三", 12);System.out.println(s1.hashCode());System.out.println(s1.hashCode());student s2 = new student("张三", 12);System.out.println(s2.hashCode());
​}
}
​

我们由上面可以得到结论:

同一个对象多次调用hashCode()方法返回的Hash值是相同的

默认情况下,实现不同对象的Hash值是不同的

通过重写Hashcode方法得到的Hash值是相同的

package dayhou40.day50;
​
import java.util.Objects;
​
public class student {private String name;private int age;
​public student(String name, int age) {this.name = name;this.age = age;}
​public student() {}
​public String getName() {return name;}
​public void setName(String name) {this.name = name;}
​public int getAge() {return age;}
​public void setAge(int age) {this.age = age;}
​@Overridepublic int hashCode() {return 0;}
}
​

注意String重写了object中的hashcode

HashSet保证集合元素唯一性的原因

如果Hash表未初始化,就对其进行初始化

根据对象的哈希值计算对象的存储位置,如果该位置没有元素,就存储元素

如果有元素则存入的元素和以前的元素进行比较Hash值

如果Hash值不同,会继续执行下去,把元素添加进来

如果哈希值相同则通过equals()方法比较如果都相同则不存储,否则就存储

LinkedHashSet

特点

1.哈希表和链表实现的set接口,具有可预测的迭代次数

2.由链表保证元素有序,也就是说元素的存储顺序和取出顺序是一致的

3.由哈希表保证元素的唯一性

package dayhou40.day51;
​
import java.util.LinkedHashSet;
​
public class LinkedhashsetTest {public static void main(String[] args) {LinkedHashSet<String> set = new LinkedHashSet<>();set.add("hi");set.add("hello");set.add("world");set.add("world");for (String s : set) {System.out.println(s);}}
}
​

TreeSet集合

Treeset集合的特点

  1. 元素有序性(这个有序性不是指存入和取出的顺序一致而是按照一定的规则进行排序,具体方法取决于构造方法)

    1. TreeSet():根据元素的自然排序进行排序

    2. TreeSet(Comparator comparator):根据指定的比较器排序

  2. 由于没有索引所以不能使用普通for遍历

  3. 是set集合不存在重复元素

自然排序

package dayhou40.day51;
​
import java.util.TreeSet;
​
public class TreesetTest {public static void main(String[] args) {TreeSet<Integer> set = new TreeSet<>();set.add(30);set.add(20);set.add(30);set.add(10);set.add(90);for (Integer integer : set) {System.out.println(integer);}}
}
​

Comparable的使用

package dayhou40.day52;
​
public class student {private String name;public int age;
​public student(String name, int age) {this.name = name;this.age = age;}
​public student() {}
​public String getName() {return name;}
​public void setName(String name) {this.name = name;}
​public int getAge() {return age;}
​public void setAge(int age) {this.age = age;}
}
​
package dayhou40.day52;
​
import java.util.TreeSet;
​
public class comparableTest {public static void main(String[] args) {TreeSet<student> set = new TreeSet<>();student s1 = new student("张三", 22);student s2 = new student("李四", 23);student s3 = new student("王五", 20);set.add(s1);set.add(s2);set.add(s3);for (student student : set) {System.out.println(student.getName()+" "+student.getAge());}}
}
​

结果出现了报错

这是为什么呢? 因为自然排序实现了compareTo方法 而在我们的学生类中我们没有继承comparable接口重写compareTo方法

这个规则如果返回值是0那么就会存储一个元素

这个规则如果返回值是1那么就会按照升序排序

这个规则如果返回值是-1那么就会按照降序排序

那么如何按照年龄的升序排序呢?

package dayhou40.day52;
​
public class student implements Comparable<student>{private String name;public int age;
​public student(String name, int age) {this.name = name;this.age = age;}
​public student() {}
​public String getName() {return name;}
​public void setName(String name) {this.name = name;}
​public int getAge() {return age;}
​public void setAge(int age) {this.age = age;}
​@Overridepublic int compareTo(student o) {return this.getAge()-o.getAge();}
}
​

如果想要升序this就放在前面,如果想要降序this就放在后面

ComparaTo方法的使用

package dayhou40.day52;
​
public class student{private String name;public int age;
​public student(String name, int age) {this.name = name;this.age = age;}
​public student() {}
​public String getName() {return name;}
​public void setName(String name) {this.name = name;}
​public int getAge() {return age;}
​public void setAge(int age) {this.age = age;}
​
​
}
​
​
package dayhou40.day52;
​
import java.util.Comparator;
import java.util.TreeSet;
​
public class comparableTest {public static void main(String[] args) {TreeSet<student> set = new TreeSet<>(new Comparator<student>() {@Overridepublic int compare(student o1, student o2) {int sum1= o1.getAge()-o2.getAge();int sum2= o1.getAge()==o2.getAge()?o1.getName().compareTo(o2.getName()):sum1;return sum2;}});student s1 = new student("张三", 22);student s2 = new student("李三", 22);student s3 = new student("李四", 23);student s4 = new student("王五", 20);set.add(s1);set.add(s2);set.add(s3);set.add(s4);for (student student : set) {System.out.println(student.getName()+" "+student.getAge());}}
}
​

我们在TreeSet<>(new Comparator<student>()然后进行排序

这篇关于Java中的Set集合和Hash值和TreeSet的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/943763

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数