java collection基本认知之set

时间:2019-02-16
本文章向大家介绍java collection基本认知之set,主要包括java collection基本认知之set使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

上一篇博客中已经讲解了部分collection集合中List的相关知识

这篇我们来讲解一下collection的另一个集合Set

Set 具有与 Collection 完全一样的接口,只是行为上不同,Set 不保存重复的元素。

Set 接口存储一组唯一,无序的对象。

set的基本属性:

  1. 互异性:一个集合中,任何两个元素都认为是不相同的,即每个元素只能出现一次。
  2. 无序性:一个集合中,每个元素的地位都是相同的,元素之间是无序的。集合上可以定义序关系,定义了序关系后,元素之间就可以按照序关系排序。但就集合本身的特性而言,元素之间没有必然的序。
  3. 空集的性质:空集是一切集合的子集。

 实现了Set接口的主要有HashSet、TreeSet、LinkedHashSet这几个共同点就是每个相同的项只保存一份。他们也有不同点,区别如下:

1.HashSet:

  HashSet使用的是相当复杂的方式来存储元素的,使用HashSet能够最快的获取集合中的元素,效率非常高(以空间换时间)。会根据hashcode和equals来庞端是否是同一个对象,如果hashcode一样,并且equals返回true,则是同一个对象,不能重复存放。 

2.TreeSet:

  TreeSet也不能存放重复对象,但是TreeSet会自动排序,如果存放的对象不能排序则会报错,所以存放的对象必须指定排序规则。排序规则包括自然排序和客户排序。

  ①自然排序:TreeSet要添加哪个对象就在哪个对象类上面实现java.lang.Comparable接口,并且重写comparaTo()方法,返回0则表示是同一个对象,否则为不同对象。

  ②客户排序:建立一个第三方类并实现java.util.Comparator接口。并重写方法。定义集合形式为TreeSet ts = new TreeSet(new 第三方类());

3.LinkedHashSet类:

      LinkedHashSet正好介于HashSet和TreeSet之间,它也是一个hash表,但它同时维护了一个双链表来记录插入的顺序,基本方法的复杂度为O(1)。

4.SortedSet:

      set本不能有序存储,sortedSet意为按照对象的比较函数对元素排序,而不是只元素的插入次序,插入顺序则用LinkedHashSet来保存,以Comparator comparator()自然方式排序,默认存进去的元素可以按照元素大小顺序自动排序。