类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类型的元素要明显的多。
相关推荐
在Java编程语言中,集合框架是处理数据的...在使用这些集合类时,确保正确地实现了equals()、hashCode()(对于HashSet和LinkedHashSet)以及Comparable或Comparator(对于TreeSet)方法,是保证集合行为正确性的关键。
Set集合在Java编程中扮演着重要的角色,它是一种不允许元素重复的...在处理自定义对象时,确保正确地重写`equals()`和`hashCode()`方法至关重要,因为这是判断对象是否相等的标准,特别是在使用HashSet和TreeSet时。
// set容器接口的实现类有HashSet和 LinkedHashSet两个 // HashSet不保证迭代顺序, LinkedHashSet按照元素插入的顺序迭代. // 学习List对象容器的使用 // List容器中的对象允许重复 // 常用的list接口的实现类有...
本篇将详细介绍Java语言中HashSet类的使用,包括其继承结构、构造函数、常用方法以及实例演示。 首先,HashSet类继承自AbstractSet类,并实现了Set接口。这意味着HashSet同时具备了Set集合的特性,如不允许包含重复...
效率较高:HashSet 的查找、插入和删除操作的时间复杂度通常是常数时间 O(1),因为它使用了哈希表进行存储和检索。 非线程安全:HashSet 类本身不是线程安全的,在多线程环境下需要进行外部同步操作,或者使用 ...
六、Java学习方法和技巧 1. 按照专题进行学习 * 将学习内容按专题进行分类,例如Java基础、算法与编程、数据库等 2. 由基础到高级,由浅入深 * 从基础知识开始学习,然后逐步深入到高级知识 3. 使用面试题来检测...
1:contains判断去重(有序) 此方法的优点的:理解起来比较简单,并且最终得到的集合也是有序...Stream 实现去重功能和其他方法不同的是,它不用新创建集合,使用自身接收一个去重的结果就可以了,并且实现代码也很简洁
Set 接口的实现类 HashSet 和 LinkedHashSet 都使用 HashMap 来存储元素。Map 接口的实现类 HashMap 和 LinkedHashMap 都使用数组和链表来存储键值对。 集合框架的选择 选择合适的集合框架非常重要。根据集合的...
在Java编程中,HashSet是一种不允许存储重复元素的集合,它实现了Set接口。HashSet是通过HashMap来实现的,其底层使用HashMap...掌握HashSet的实现原理对于Java开发者在实际编程中合理地选择和使用集合类具有重要意义。
Java 8引入了新的日期时间API(`java.time`包),但`java.util.Date`和`java.util.Calendar`仍然广泛使用。 7. Comparator接口:Comparator用于比较对象的顺序,可以自定义比较规则。在集合排序或TreeMap/TREEset中...
HashSet、LinkedHashSet和TreeSet是Set接口的主要实现类。 - HashSet:基于哈希表(HashMap)实现,插入和查找速度快,但无序。哈希表根据对象的哈希码进行存储,因此元素的顺序不可预知。 - LinkedHashSet:在...
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 是 Java 中的一种对象...Collection、List、Set 和 Map 等集合类是 Java 中非常重要的一部分,需要深入了解其用法和区别,以便更好地使用集合类来实现业务逻辑。
理解其内部机制和使用方法,对于编写高效的Java代码至关重要。在黑马程序员_毕向东_Java基础视频教程中,你可能会更详细地学习到关于HashSet的实现原理和实战技巧。通过观看相关视频和实践操作,可以加深对HashSet的...
2. Set接口:Set接口的实现类主要有HashSet、LinkedHashSet和TreeSet。HashSet是基于哈希表实现的,不保证元素的顺序,但查找速度快;LinkedHashSet在HashSet基础上保持了元素的插入顺序;而TreeSet则由红黑树实现,...
节点流和处理流 Java IO 的核心类 File Java IO 流对象 字节流对象InputStream OutputStream 字符流对象Reader Writer 字节流与字符流的转换新潮的 NIO 缓冲区(Buffer)通道(Channel) 示例:文件拷贝案例 BIO 和 NIO ...
* Set:HashSet、LinkedHashSet、TreeSet * List:ArrayList、LinkedList * Map:HashMap、TreeMap ArrayList 是一个可以自动增长容量的数组,我们可以将其看作是一个可以自动增长容量的数组。ArrayList 提供了 ...
Set接口不允许重复元素,如HashSet、LinkedHashSet和TreeSet。HashSet基于哈希表,不保证元素顺序;LinkedHashSet保留插入顺序;TreeSet基于红黑树,元素按自然顺序或自定义比较器排序。 Queue接口用于先进先出...