java中的hashset_Java中的HashSet

java中的hashset

介绍:

Java中的HashSet实现Set接口,即它不允许重复。 它在内部由HashMap支持,该哈希表基于哈希原理。

我们可以在HashSet中存储一个值。 默认容量为16,负载系数为0.75,其中:

Load factor = Number of Stored Elements / capacity

Java HashSet是不同步的。 同样,不能保证保留元素的插入顺序。

在本教程中,我们将学习如何使用Java HashSet

实例化

我们可以使用以下构造函数之一创建Java HashSet

HashSet() // default capacity of 16 with a load factor of 0.75
HashSet(int initialCapacity)
HashSet(int initialCapacity, float loadFactor)
HashSet(Collection c)

这些构造函数的用法都很直观。

让我们使用默认构造函数快速创建一个HashSet:

Set<Integer> set = new HashSet<>();

常用方法:

现在让我们看一些可以帮助我们操纵Java HashSet的方法:

1.

它只是将元素添加到给定的集合(如果尚不存在)。 如果该元素已经存在,则add()仅返回false:

System.out.println(set.add(1));  //true
System.out.println(set.add(2));  //true
System.out.println(set.add(3));  //true
System.out.println(set.add(1));  //false - as already present//Note that the order of elements isn't guaranteed
System.out.println(set); //[1, 2, 3]

2.

如果元素在引用集中存在,则contains()方法返回true ,否则返回false

System.out.println(set.contains(1)); //true
System.out.println(set.contains(4)); //false

3.

顾名思义,它将删除元素obj(如果存在)并返回true 。 如果不存在这样的元素,则仅返回false

System.out.println(set.remove(1)); //true
System.out.println(set.remove(4)); //false

请注意, HashSet还继承了removeAll()removeIf()方法,可用于删除值。

4.

对于空集返回true ,否则返回false

System.out.println(set.isEmpty()); // false

5. int

它仅返回给定集中存在的元素数。

6.

clear()方法删除引用集中存在的所有值,从而使其成为空集。

内部实施:

HashSet在内部使用HashMap来存储其元素。 存储在HashSet中的元素被映射为HashMap中的键。 所有这些条目的值字段都包含一个常量PRESENT:

private static final Object PRESENT = new Object();

这是一个虚拟对象。

遍历

我们可以使用以下一种方式来迭代HashSet中的元素:

1.

从Java 8开始,我们可以使用forEach()遍历任何Java 集合:

set.forEach(e -> System.out.println(e));

2.

Java 8还支持forEachRemaining()构造,该构造可与Collection上的任何迭代器一起使用:

Iterator<Integer> itr = set.iterator();itr.forEachRemaining(e -> System.out.println(e));

3.使用

如果我们使用的是Java 7或更低版​​本,我们可以简单地使用迭代器进行迭代:

Iterator<Integer> itr = set.iterator();while(itr.hasNext()) {System.out.println(itr.next());
}

4.扩展

我们还可以使用扩展的for循环遍历元素:

for(Integer e : set) {System.out.println(e);
}

结论:

在本教程中,我们学习了如何创建和使用Java HashSet。 我们也知道Java HashSet在内部使用HashMap来实现它。

成为第一个发表评论的人。

翻译自: https://www.javacodegeeks.com/2019/04/hashset-java.html

java中的hashset

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/332331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

win32bridge.server.exe函数不正确_修电脑?不,其实我们学的是......

COMPUTER计信学子Python?JAVA?C?C?HTML?身为重师计信人逢年过节总免不了被亲戚们“盘问”一番必问清单第一名就是“专业”他们往往从字面去理解而我们计信人被误解的频率相当高“学计算机的肯定会修电脑对吧”请接着看下去吧!我们学的到底是什么&#xff1f;(点击查看答案…

SimpleDateFormat详解

SimpleDateFormat 中的时间标识含义&#xff1a; G 年代标志符 y 年 M 月 d 日 h 时 在上午或下午 (1~12) H 时 在一天中 (0~23) m 分 s 秒 S 毫秒 E 星期 D 一年中的第几天 F 一月中第几个星期几 w 一年中第几个星期 W 一月中第几个星期 a 上午 / 下午 标记符 k 时 在一天中 …

java uuid_Java UUID

java uuid介绍&#xff1a; UUID&#xff08;通用唯一标识符&#xff09;表示一个128位长的唯一值 。 它也被普遍称为GUID&#xff08;全球唯一标识符&#xff09;。 UUID的标准表示形式由十六进制数字组成&#xff1a; 533a4559-e55c-18b3-8456-555563322002并具有36个字符 …

JDK 9.0.4 报错:程序包 com.sun.xml.internal.fastinfoset.stax.events 不存在/不可见

IDE&#xff1a;IntelliJ IDEA 构建工具&#xff1a;Maven JDK版本&#xff1a;JDK 9.0.4 在代码中使用下面的工具类&#xff1a; com.sun.xml.internal.fastinfoset.stax.events.Util报错如下&#xff1a; 或者 光标移到 Util 处&#xff0c;按下 Option Enter&#xff1a…

3650m5设置u盘启动_系统重装必备神器,U盘如何制作启动盘?

早些年的时候&#xff0c;电脑安装系统需要光盘&#xff0c;但是现在光盘也逐渐退出历史舞台。不管是台式计算机还是笔记本&#xff0c;光驱这个东西也逐渐消失。如果自己的计算机没有光驱&#xff0c;电脑又无法开机需要重装系统&#xff0c;这个时候该怎么办呢&#xff1f;可…

jtable隐藏全部_全部隐藏!

jtable隐藏全部在较早的文章中 &#xff0c;我写了以下几句话&#xff1a; 在面向对象的代码库中&#xff0c;该工具包应尽可能离散。 您使用开发套件的次数越多&#xff0c;您的代码实际面向对象的次数就越少&#xff0c;或者您的抽象并不是最好的。 。 我认为有必要详细说明…

IntelliJ IDEA 如何多模块开发

参考&#xff1a; https://blog.csdn.net/jqc874789596/article/details/86609554

距离矢量路由算法的java代码_八大排序算法比较(附Java代码)

冒泡排序/*** 冒泡排序 比较好理解* 两两相比 较大的放后面* 时间复杂度O(n^2)*//*** 改进前的冒泡排序算法进行100,000数据排序运行时间为&#xff1a;3829ms* 优化后的冒泡排序算法进行100,000数据排序运行时间为&#xff1a;3551ms*/ public static void bubbleSort(int[] a…

jaxb注解使用_使用JAXB时

jaxb注解使用并没有很多例子可以说明这一点&#xff0c;但是如何在应用程序中使用JAXB可以在性能&#xff08;和内存使用&#xff09;方面产生巨大差异。 这个例子 在此博客文章中&#xff0c;我将使用一个名为Membership的示例对象&#xff0c;看起来像这样&#xff1a; 我们…

org.apache.tomcat.util.descriptor.web.WebXml.setVersion 未知版本字符串 [4.0]

参考&#xff1a; https://blog.csdn.net/qq_40829288/article/details/93936261 https://www.shuzhiduo.com/A/Ae5RnvaN5Q/ https://www.cnblogs.com/youpeng/p/11095504.html

python无法安装pycurl_Python安装pycurl失败的解决方法

Centos安装pycurlcentos 安装pycurlyum install python-devel curl-develpip3 install pycurlMac(老版本)安装pycurl解决MacOS升级后出现xcrun: error: invalid active developer path, missing xcrun的问题xcode-select --install然后dongchang-5:qqmusic baoshan$ pip3 insta…

组装一台计算机 java_如何在同一台计算机上安装多个Java版本

组装一台计算机 java一段时间以前&#xff0c;我写了一篇文章《 用示例解释Java Lambda表达式》&#xff0c;但是我很容易浏览Java 8&#xff0c;因为我在项目中使用了Java 8&#xff0c;并且允许我安装和使用它。 但是在我当前的项目中&#xff0c;我们仍在使用Java 8&#xf…

字符串类型的日期如何存储到数据表Date类型的字段中

在使用 JDBC 访问数据库存储数据时&#xff0c;日期类型的数据必须是 java.sql.Date 的才能注入到 SQL 语句中。 因此这里是将字符串类型的日期转换成 java.util.Date&#xff0c;接着再转换成 java.sql.Date &#xff0c;最后注入到 SQL 语句中。 public class ProjectDAO { …

python执行linux命令返回结果_python执行linux命令的简单示例

对python执行linux命令的两种方法感兴趣的小伙伴&#xff0c;下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧&#xff01;python执行linux命令有两种方法&#xff1a;在此以Linux常用的ls命令为例&#xff1a;方法一&#xff1a;使用os模块shell# python>> import os…

web api开启错误提示_当HTTP状态代码不足时:处理Web API错误报告

web api开启错误提示RESTful Web API设计的一个领域&#xff08;经常被忽视&#xff09;是如何报告与业务或应用程序有关的错误和问题。 首先要想到HTTP状态代码的正确用法&#xff0c;尽管非常方便&#xff0c;但通常它的信息量还不够。 让我们以400错误请求为例。 是的&#…

会议室分配时间最长_论文导论动态任务分配GPU上图计算的高效处理方式

编者按GPU作为一种硬件&#xff0c;相比较于CPU来说&#xff0c;有更多的并行度和更高的带宽&#xff0c;在图像处理领域取得了非常好的应用效果。越来越多的研究也正试图将GPU也应用到图计算领域中&#xff0c;然而GPU适合进行规则运算&#xff0c;但是图是一种不规则的数据表…

JS(Javascript)校验表单项的内容是否合规

<script !src"">/*** 分析&#xff1a;* 1.给表单绑定onsubmit事件* 监听器中判断每个方法检验的结果&#xff0c;如果都是true&#xff0c;则监听器方法返回true&#xff1b;如果有一个为false,* 则监听器方法返回false* 2.定义一些方法分别校验各个表单项* 3…

java \t怎么从头开始_如何从头开始以正确的面向对象方式创建Java Web Framework

java \t怎么从头开始您如何用Java设计Web应用程序&#xff1f; 您安装了Spring&#xff0c;阅读了手册&#xff0c;创建了控制器 &#xff0c;创建了一些视图&#xff0c;添加了一些注释 &#xff0c;它就可以工作了。 如果没有Spring &#xff08;Ruby中没有Ruby on Rails&…

kl散度的理解_以曲率的视角理解自然梯度优化

一个故事我要讲一个故事:一个你几乎肯定听过的故事&#xff0c;但它的侧重点与你习以为常关注的不同。所有现代深度学习模型都使用梯度下降进行训练。 在梯度下降的每个步骤中&#xff0c;您的参数值从某个起始点开始&#xff0c;然后将它们移动到最大损失减少的方向。 你可以通…

JSP的学习笔记

文章目录概念原理JSP 脚本JSP 内置对象概念 Java Server Pages &#xff1a;Java 服务器端页面 可以理解为&#xff1a;一个特殊的页面&#xff0c;其中既可以指定定义 html 标签&#xff0c;又可以定义 Java 代码 用于简化 Servlet 中的输出页面数据的代码的书写!!! 原理 J…