热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用示例链接Java中的hashset

用示例链接 Java 中的 hashset原文:https://www . geeksforgeeks . org/link e

用示例链接 Java 中的 hashset

原文:https://www . geeksforgeeks . org/link edhashset-in-Java-with-examples/

链接哈希集是哈希集的有序版本,它维护所有元素的双向链表。当需要维护迭代顺序时,使用这个类。当迭代一个 HashSet 时,顺序是不可预测的,而 LinkedHashSet 让我们按照元素插入的顺序迭代元素。当使用迭代器循环遍历 LinkedHashSet 时,元素将按照插入的顺序返回。

链接哈希集的层次结构

LinkedHashSet in Java with Examples

类型参数:


  • E–该集合维护的元素类型

所有实现的接口:


  • 可序列化

  • 可克隆

  • 可重复T1】

  • 集合T1】

  • 设定T1

申报:

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



  • 仅包含像 HashSet 这样的独特元素。它扩展了 HashSet 类并实现了 Set 接口。

  • 保持插入顺序。


LinkedHashSet 类的构造函数:

1。LinkedHashSet(): 此构造函数用于创建默认的 HashSet

LinkedHashSet hs = new LinkedHashSet ();

2。LinkedHashSet(集合 C): 用于用集合 C 的元素初始化 HashSet

LinkedHashSet hs = new LinkedHashSet (Collection c);

3。LinkedHashSet(int size): 用于用参数中提到的整数初始化 LinkedHashSet 的大小。

LinkedHashSet hs = new LinkedHashSet (int size);

4。LinkedHashSet(int capacity,float fillRatio): 可以用参数中提到的参数来初始化容量和填充比,也称为 LinkedHashSet 的负载容量。当元素数量超过哈希集的容量时,将乘以填充比,从而扩展 LinkedHashSet 的容量。

linkedinhashseths =新 linkedinhashset(int capacity,int fill ratio);

示例:

Java 语言(一种计算机语言,尤用于创建网站)


// Java Program to illustrate the LinkedHashSet
import java.util.LinkedHashSet; 
public class LinkedHashSetExample 
{  
      // Main Method
    public static void main(String[] args) 
    {  
        LinkedHashSet<String> linkedset = 
                           new LinkedHashSet<String>();  
        // Adding element to LinkedHashSet  
        linkedset.add("A");  
        linkedset.add("B");  
        linkedset.add("C");  
        linkedset.add("D"); 
        // This will not add new element as A already exists 
        linkedset.add("A"); 
        linkedset.add("E");  
        System.out.println("Size of LinkedHashSet = " +
                                    linkedset.size());  
        System.out.println("Original LinkedHashSet:" + linkedset);  
        System.out.println("Removing D from LinkedHashSet: " +
                            linkedset.remove("D"));  
        System.out.println("Trying to Remove Z which is not "+
                            "present: " + linkedset.remove("Z"));  
        System.out.println("Checking if A is present=" + 
                            linkedset.contains("A"));
        System.out.println("Updated LinkedHashSet: " + linkedset);  
    }  
}  

输出:

Size of LinkedHashSet=5
Original LinkedHashSet:[A, B, C, D, E]
Removing D from LinkedHashSet: true
Trying to Remove Z which is not present: false
Checking if A is present=true
Updated LinkedHashSet: [A, B, C, E]


对 LinkedHashSet 类执行各种操作

让我们看看如何在 LinkedHashSet 上执行一些常用的操作。

1。添加元素:为了给 LinkedHashSet 添加一个元素,我们可以使用 add() 方法。这与 HashSet 不同,因为在 HashSet 中,插入顺序不被保留,而是保留在 LinkedHashSet 中。

Java 语言(一种计算机语言,尤用于创建网站)


// Java program for adding
// elements to LinkedHashSet
import java.util.*;
import java.io.*;
class AddingElementsToLinkedHashSet {
    public static void main(String[] args)
    {
        // create an instance of
        // LinkedHashSet
        LinkedHashSet<String> hs
            = new LinkedHashSet<String>();
        // Elements are added using add() method
        // insertion order is maintained
        hs.add("Geek");
        hs.add("For");
        hs.add("Geeks");
        // print elements to the console
        System.out.println("LinkedHashSet : " + hs);
    }
}

Output:

LinkedHashSet : [Geek, For, Geeks]

2。移除元素:可以使用移除()方法从链接的哈希集中移除值。

Java 语言(一种计算机语言,尤用于创建网站)


// Java program to remove elements
// from LinkedHashSet
import java.io.*;
import java.util.*;
class RemoveElementsFromLinkedHashSet {
    public static void main(String[] args)
    {
        // create an instance of
        // LinkedHashSet
        LinkedHashSet<String> hs
            = new LinkedHashSet<String>();
        // Elements are added using add() method
        hs.add("Geek");
        hs.add("For");
        hs.add("Geeks");
        hs.add("A");
        hs.add("B");
        hs.add("Z");
        // print elements to the console
        System.out.println("Initial HashSet " + hs);
        // Removing the element b
        hs.remove("B");
        System.out.println("After removing element " + hs);
        // Returns false if the element is not present
        System.out.println(hs.remove("AC"));
    }
}

Output:

Initial HashSet [Geek, For, Geeks, A, B, Z]
After removing element [Geek, For, Geeks, A, Z]
false


推荐阅读
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • Java 架构:深入理解 JDK 动态代理机制
    代理模式是 Java 中常用的设计模式之一,其核心在于代理类与委托类共享相同的接口。代理类主要用于为委托类提供预处理、过滤、转发及后处理等功能,以增强或改变原有功能的行为。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 尽管某些细分市场如WAN优化表现不佳,但全球运营商路由器和交换机市场持续增长。根据最新研究,该市场预计在2023年达到202亿美元的规模。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 本文介绍了如何在 C# 和 XNA 框架中实现一个自定义的 3x3 矩阵类(MMatrix33),旨在深入理解矩阵运算及其应用场景。该类参考了 AS3 Starling 和其他相关资源,以确保算法的准确性和高效性。 ... [详细]
  • 深入解析:OpenShift Origin环境下的Kubernetes Spark Operator
    本文探讨了如何在OpenShift Origin平台上利用Kubernetes Spark Operator来管理和部署Apache Spark集群与应用。作为Radanalytics.io项目的一部分,这一开源工具为大数据处理提供了强大的支持。 ... [详细]
author-avatar
白宇2502858015
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有