`
wbj0110
  • 浏览: 1603604 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

Java HashSet和LinkedHashSet的用法

    博客分类:
  • Java
阅读更多

 类HashSet和LinkedHashSet都是接口Set的实现,两者都不能保存重复的数据。主要区别是HashSet不保证集合中元素的顺序,即不能保证迭代的顺序与插入的顺序一致。

而LinkedHashSet按照元素插入的顺序进行迭代,即迭代输出的顺序与插入的顺序保持一致。

以下是HastSet和LinkedHashSet的用法示例:

 

import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.Set;


public class JavaTest {
	
	// HashSet不保证集合的迭代顺序;也许在某些时间迭代的顺序与插入顺序一致,但是不保证该顺序恒久不变。
	private static Set<Integer> mSetInt = new HashSet<Integer>();
	private static Set<String> mSetString = new HashSet<String>();
	
	// LinkedHashSet按照元素插入的顺序进行迭代,LinkedHashSet不是线程安全的。
	private static Set<Integer> mLinkedSetInt = Collections.synchronizedSet(new LinkedHashSet<Integer>());
	private static Set<String> mLinkedSetString = Collections.synchronizedSet(new LinkedHashSet<String>());

	/**
	 * @param args
	 */
	public static void main(String[] args) {

		for (int i = 0; i < 50; i++) {
			mSetInt.add(i);
			mSetString.add(String.valueOf(i));
			mLinkedSetInt.add(i);
			mLinkedSetString.add(String.valueOf(i));
		}
		
		Iterator<Integer> setIntIt = mSetInt.iterator();
		System.out.println("The sequence of HashSet for Integer:");
		while(setIntIt.hasNext()) {
			System.out.print(setIntIt.next() + " ");
		}
		System.out.println();
		
		System.out.println("The sequence of HashSet for String:");
		Iterator<String> setStringIt = mSetString.iterator();
		while(setStringIt.hasNext()) {
			System.out.print(setStringIt.next() + " ");
		}
		System.out.println();
		
		System.out.println("The sequence of LinkedHashSet for Integer:");
		Iterator<Integer> linkedSetIntIt = mLinkedSetInt.iterator();
		while(linkedSetIntIt.hasNext()) {
			System.out.print(linkedSetIntIt.next() + " ");
		}
		System.out.println();
		
		System.out.println("The sequence of LinkedHashSet for String:");
		Iterator<String> linkedSetStringIt = mLinkedSetString.iterator();
		while(linkedSetStringIt.hasNext()) {
			System.out.print(linkedSetStringIt.next() + " ");
		}
		System.out.println();
	}

}

输出结果如下:

The sequence of HashSet for Integer:
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 17 16 19 18 21 20 23 22 25 24 27 26 29 28 31 30 34 35 32 33 38 39 36 37 42 43 40 41 46 47 44 45 49 48 
The sequence of HashSet for String:
35 36 33 34 39 37 38 43 42 41 40 22 23 24 25 26 27 28 29 3 2 1 0 7 30 6 5 32 4 31 9 8 19 17 18 15 16 13 14 11 12 21 20 49 48 45 44 47 46 10 
The sequence of LinkedHashSet for Integer:
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 
The sequence of LinkedHashSet for String:
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 

从输出结果看,如果HastSet中保存的是Integer类型和String类型的对象,迭代的顺序与插入的顺序不一致,其中String类型的元素不一致的情况比Integer类型的元素要明显的多。

分享到:
评论

相关推荐

    HashSet,TreeSet和LinkedHashSet的区别1

    在Java编程语言中,集合框架是处理数据的...在使用这些集合类时,确保正确地实现了equals()、hashCode()(对于HashSet和LinkedHashSet)以及Comparable或Comparator(对于TreeSet)方法,是保证集合行为正确性的关键。

    Java—Set集合详解(HashSet/LinkedHashSet/TreeSet/EnumSet)

    Set集合在Java编程中扮演着重要的角色,它是一种不允许元素重复的...在处理自定义对象时,确保正确地重写`equals()`和`hashCode()`方法至关重要,因为这是判断对象是否相等的标准,特别是在使用HashSet和TreeSet时。

    java中set、list和map的使用方法实例

    // set容器接口的实现类有HashSet和 LinkedHashSet两个 // HashSet不保证迭代顺序, LinkedHashSet按照元素插入的顺序迭代. // 学习List对象容器的使用 // List容器中的对象允许重复 // 常用的list接口的实现类有...

    hashset类的使用

    本篇将详细介绍Java语言中HashSet类的使用,包括其继承结构、构造函数、常用方法以及实例演示。 首先,HashSet类继承自AbstractSet类,并实现了Set接口。这意味着HashSet同时具备了Set集合的特性,如不允许包含重复...

    java集合-HashSet的使用

    效率较高:HashSet 的查找、插入和删除操作的时间复杂度通常是常数时间 O(1),因为它使用了哈希表进行存储和检索。 非线程安全:HashSet 类本身不是线程安全的,在多线程环境下需要进行外部同步操作,或者使用 ...

    Java面试总结,Redis宕机数据丢失解决方案,看完这篇彻底明白了.docx

    六、Java学习方法和技巧 1. 按照专题进行学习 * 将学习内容按专题进行分类,例如Java基础、算法与编程、数据库等 2. 由基础到高级,由浅入深 * 从基础知识开始学习,然后逐步深入到高级知识 3. 使用面试题来检测...

    List 去重的6种方法(contains、迭代、hashSet、treeSet、linkedHashSet、stream)

    1:contains判断去重(有序) 此方法的优点的:理解起来比较简单,并且最终得到的集合也是有序...Stream 实现去重功能和其他方法不同的是,它不用新创建集合,使用自身接收一个去重的结果就可以了,并且实现代码也很简洁

    Java集合框架常见面试题

    Set 接口的实现类 HashSet 和 LinkedHashSet 都使用 HashMap 来存储元素。Map 接口的实现类 HashMap 和 LinkedHashMap 都使用数组和链表来存储键值对。 集合框架的选择 选择合适的集合框架非常重要。根据集合的...

    HashSet的实现原理

    在Java编程中,HashSet是一种不允许存储重复元素的集合,它实现了Set接口。HashSet是通过HashMap来实现的,其底层使用HashMap...掌握HashSet的实现原理对于Java开发者在实际编程中合理地选择和使用集合类具有重要意义。

    java工具类 java开发助手 java util

    Java 8引入了新的日期时间API(`java.time`包),但`java.util.Date`和`java.util.Calendar`仍然广泛使用。 7. Comparator接口:Comparator用于比较对象的顺序,可以自定义比较规则。在集合排序或TreeMap/TREEset中...

    Java集合概述与实例分析

    HashSet、LinkedHashSet和TreeSet是Set接口的主要实现类。 - HashSet:基于哈希表(HashMap)实现,插入和查找速度快,但无序。哈希表根据对象的哈希码进行存储,因此元素的顺序不可预知。 - LinkedHashSet:在...

    【Java面试+Java学习指南】 一份涵盖大部分Java程序员所需要掌握的核心知识

    Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解2:Queue和LinkedList Java集合详解3:Iterator,fail-fast机制与比较器 Java集合详解4:HashMap和HashTable Java集合详解5:深入...

    Collection,List,Set和_Map用法和区别

    Collection, List, Set 和 Map 用法和区别 Collection 是 Java 中的一种对象...Collection、List、Set 和 Map 等集合类是 Java 中非常重要的一部分,需要深入了解其用法和区别,以便更好地使用集合类来实现业务逻辑。

    集合类HashSet

    理解其内部机制和使用方法,对于编写高效的Java代码至关重要。在黑马程序员_毕向东_Java基础视频教程中,你可能会更详细地学习到关于HashSet的实现原理和实战技巧。通过观看相关视频和实践操作,可以加深对HashSet的...

    Java集合排序及java集合类详解

    2. Set接口:Set接口的实现类主要有HashSet、LinkedHashSet和TreeSet。HashSet是基于哈希表实现的,不保证元素的顺序,但查找速度快;LinkedHashSet在HashSet基础上保持了元素的插入顺序;而TreeSet则由红黑树实现,...

    Java 基础核心总结 +经典算法大全.rar

    节点流和处理流 Java IO 的核心类 File Java IO 流对象 字节流对象InputStream OutputStream 字符流对象Reader Writer 字节流与字符流的转换新潮的 NIO 缓冲区(Buffer)通道(Channel) 示例:文件拷贝案例 BIO 和 NIO ...

    java集合类详解(set list ArrayList等java集合类详述)

    * Set:HashSet、LinkedHashSet、TreeSet * List:ArrayList、LinkedList * Map:HashMap、TreeMap ArrayList 是一个可以自动增长容量的数组,我们可以将其看作是一个可以自动增长容量的数组。ArrayList 提供了 ...

    java 集合和内部类资料

    Set接口不允许重复元素,如HashSet、LinkedHashSet和TreeSet。HashSet基于哈希表,不保证元素顺序;LinkedHashSet保留插入顺序;TreeSet基于红黑树,元素按自然顺序或自定义比较器排序。 Queue接口用于先进先出...

Global site tag (gtag.js) - Google Analytics