1. 关键技术:
  2. HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode方法。
  3. TreeSet采用红黑树的数据结构进行排序元素,使用它可以从Set中提取有序(升序或者降序)的序列。需要注意的是,存入自定义类时,TreeSet需要维护元素的存储顺序,因此自定义类要实现Comparable接口并定义compareTo方法。
  4. LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
关键技术:

    HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode方法。
TreeSet采用红黑树的数据结构进行排序元素,使用它可以从Set中提取有序(升序或者降序)的序列。需要注意的是,存入自定义类时,TreeSet需要维护元素的存储顺序,因此自定义类要实现Comparable接口并定义compareTo方法。
LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
  1. package book.arrayset;
  2. import java.util.ArrayList;
  3. import java.util.HashSet;
  4. import java.util.Iterator;
  5. import java.util.LinkedHashSet;
  6. import java.util.List;
  7. import java.util.Set;
  8. import java.util.TreeSet;
  9. /**
  10. * 演示各种Set的使用
  11. * 存入Set的每个元素必须是唯一的,因为Set不保存重复元素。
  12. */
  13. public class TestSet {
  14. /**
  15. * 初始化Set的元素
  16. * @param set
  17. */
  18. public static void init(Set set){
  19. if (set != null){
  20. set.add("aaa");
  21. set.add("ccc");
  22. set.add("bbb");
  23. set.add("eee");
  24. set.add("ddd");
  25. }
  26. }
  27. /**
  28. * 输出set的元素
  29. * @param set
  30. */
  31. public static void output(Set set){
  32. if (set != null){
  33. //使用迭代器遍历Set,也只有这一种方法
  34. Iterator it = set.iterator();
  35. while (it.hasNext()){
  36. System.out.print(it.next() + " ");
  37. }
  38. }
  39. System.out.println();
  40. }
  41. /**
  42. * 使用HashSet
  43. */
  44. public static void testHashSet(){
  45. Set mySet = new HashSet();
  46. init(mySet);
  47. System.out.println("使用HashSet: ");
  48. output(mySet);
  49. }
  50. /**
  51. * 使用TreeSet
  52. */
  53. public static void testTreeSet(){
  54. Set mySet = new TreeSet();
  55. init(mySet);
  56. System.out.println("使用TreeSet: ");
  57. output(mySet);
  58. }
  59. /**
  60. * 使用LinkedHashSet
  61. */
  62. public static void testLinkedHashSet(){
  63. Set mySet = new LinkedHashSet();
  64. init(mySet);
  65. System.out.println("使用LinkedHashSet: ");
  66. output(mySet);
  67. }
  68. public static void main(String[] args) {
  69. TestSet.testHashSet();
  70. TestSet.testTreeSet();
  71. TestSet.testLinkedHashSet();
  72. Set mySet = new HashSet();
  73. init(mySet);
  74. //Set不允许元素重复
  75. mySet.add("aaa");
  76. mySet.add("bbb");
  77. System.out.println("为mySet加入aaa, bbb元素后: ");
  78. output(mySet);
  79. //删除元素
  80. mySet.remove("aaa");
  81. System.out.println("mySet删除aaa元素后: ");
  82. output(mySet);
  83. //增加另外一个集合中的所有元素
  84. List list = new ArrayList();
  85. list.add("aaa");
  86. list.add("aaa");
  87. list.add("fff");
  88. mySet.addAll(list);
  89. System.out.println("mySet添加另外一个集合的所有元素后: ");
  90. output(mySet);
  91. //删除除了另外一个集合包含的以外的所有元素
  92. mySet.retainAll(list);
  93. System.out.println("mySet删除除了另外一个集合包含的以外的所有元素后: ");
  94. output(mySet);
  95. //删除另外一个集合包含的所有元素
  96. mySet.removeAll(list);
  97. System.out.println("mySet删除另外一个集合包含的所有元素后: ");
  98. output(mySet);
  99. //获取Set中元素的个数
  100. System.out.println("mySet中当前元素的个数: " + mySet.size());
  101. //判断Set中元素个数是否为0
  102. System.out.println("mySet中当前元素为0?  " + mySet.isEmpty());
  103. /**
  104. * (1)Set不允许重复元素,因此加入Set的Object必须定义equals()方法以确保对象的唯一性。
  105. * (2)HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode()。
  106. * (3)TreeSet采用红黑树的数据结构进行排序元素,能保证元素的次序,使用它可以从Set中提取有序的序列。
  107. * 需要注意的是,生成自己的类时,Set需要维护元素的存储顺序,因此要实现Comparable接口并定义compareTo()方法。
  108. * (4)LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素的插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
  109. */
  110. }
  111. }

HashSet、LinkedHashSet和TreeSet的更多相关文章

  1. HashSet、LinkedHashSet、TreeSet

    以下内容基于jdk1.7.0_79源码: 关于HashSet.LinkedHashSet.TreeSet Set接口的实现类,最大特点是不允许出现重复元素: HashSet:基于HashMap实现,一 ...

  2. 规则集之探究何时使用HashSet、LinkedHashSet以及TreeSet?

    前言 Java集合框架三种主要类型的集合:规则集(Set).线性表(List).队列(Queue).Set用来存储不可重复的元素:List用来存储有元素构成的有序的集合:而Queue则用于存储用先进先 ...

  3. Java集合框架(二)—— HashSet、LinkedHashSet、TreeSet和EnumSet

    Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合与Collection基本上完全一样,它没有提供任何额外的方法. Se ...

  4. 一、集合框架(关于ArrayList,LinkedList,HashSet,LinkedHashSet,TreeSet)

    一.ArrayList 解决了数组的局限性,最常见的容器类,ArrayList容器的容量capacity会随着对象的增加,自动增长.不会出现数组边界的问题. package collection;   ...

  5. 09 Collection,Iterator,List,listIterator,Vector,ArrayList,LinkedList,泛型,增强for,可变参数,HashSet,LinkedHashSet,TreeSet

    09 Collection,Iterator,List,listIterator,Vector,ArrayList,LinkedList,泛型,增强for,可变参数,HashSet,LinkedHas ...

  6. java集合框架之几种set(HashSet LinkedHashSet TreeSet )

    参考http://how2j.cn/k/collection/collection-sets/691.html#nowhere HashSet LinkedHashSet TreeSet HashSe ...

  7. Java集合系列(三):HashSet、LinkedHashSet、TreeSet的使用方法及区别

    本篇博客主要讲解Set接口的三个实现类HashSet.LinkedHashSet.TreeSet的使用方法以及三者之间的区别. 注意:本文中代码使用的JDK版本为1.8.0_191 1. HashSe ...

  8. Java中的集合HashSet、LinkedHashSet、TreeSet和EnumSet(二)

    Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合于Collection基本上完全一样,它没有提供任何额外的方法. Se ...

  9. Java自学-集合框架 HashSet、LinkedHashSet、TreeSet之间的区别

    HashSet. LinkedHashSet.TreeSet之间的区别 步骤 1 : HashSet LinkedHashSet TreeSet HashSet: 无序 LinkedHashSet: ...

  10. Java Set 常用集合 HashSet、LinkedHashSet、TreeSet

    Java 中的 Set 是非常常用的数据类型.Set 是无序的 Collection,Java Set 有三个常用的实现类,分别是:HashSet.LinkedHashSet.TreeSet 本文基于 ...

随机推荐

  1. css3实现圆角边框渐变

    <button class="border">112233</button> 创建button .border{ position: relative; b ...

  2. React跨域问题解决

    https://segmentfault.com/q/1010000012732581 非跨域问题报错 -rpccorsdomain="http://localhost:3000" ...

  3. 错误error: Exception at 0x613baa14, code: 0xc0000005: read access violation at: 0x0, flags=0x0 (first chance)的解决办法

    一.错误原因 出现这个错误的原因多半是由于指针出现错误,即出现了空指针,也有说是变量没有初始化,笔者碰到的情况是发生了内存溢出. 二.定位方法 一般这种问题直接导致程序崩溃,直接调试,就能找到对应的问 ...

  4. android 远程Service以及AIDL的跨进程通信

    在Android中,Service是运行在主线程中的,如果在Service中处理一些耗时的操作,就会导致程序出现ANR. 但如果将本地的Service转换成一个远程的Service,就不会出现这样的问 ...

  5. 201621123033 《Java程序设计》第9周学习总结

    第九次作业 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 1.2 选做:收集你认为有用的代码片段 //stream(),filter(),collect() ...

  6. 【bzoj4994】[Usaco2017 Feb]Why Did the Cow Cross the Road III 树状数组

    题目描述 给定长度为2N的序列,1~N各处现过2次,i第一次出现位置记为ai,第二次记为bi,求满足ai<aj<bi<bj的对数 样例输入 4 3 2 4 4 1 3 2 1 样例输 ...

  7. 【bzoj2694】Lcm 莫比乌斯反演+线性筛

    题目描述 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^m|\mu(gcd(i,j))|lcm(i,j)$,即$gcd(i,j)$不存在平方因子的$lcm(i,j)$之 ...

  8. 【bzoj4894】天赋 矩阵树定理

    题目描述 小明有许多潜在的天赋,他希望学习这些天赋来变得更强.正如许多游戏中一样,小明也有n种潜在的天赋,但有一些天赋必须是要有前置天赋才能够学习得到的.也就是说,有一些天赋必须是要在学习了另一个天赋 ...

  9. Search Engine —— Regular Expression(Spider)

    Regular Expression,即正则表达式:用来查找符合某些负责规则的字符串的需要.它真是用于描述这些规则的工具. 1. \b 是一个元字符,用来匹配一个位置,代表着单词的开头或结尾,也就是单 ...

  10. 《R语言实战》读书笔记--第三章 图形初阶(一)

    3.1使用图形 可以使用pdf等函数将图形直接保存在文件中.在运用attach和detach函数的使用中经常出现错误,比如命名重复的问题,所以,应该尽量避免使用这两个函数. plot是一般的画图函数, ...