Java容器:Set

时间:2023-03-08 17:49:01

Set和数学中的集合十分类似,在Java中,Set是一种绝不会包含两个相等元素的存储结构。在阅读此文前请阅读Java容器:Map

Set方法

增添方法:

  • boolean add(E e);
  • boolean addAll(Collection c);将参数容器与该Set对象做并集。

    查询方法:
  • int size();
  • boolean isEmpty();
  • boolean equals(Object o);
  • Iterator<E> iterator();对Set对象迭代需要使用迭代器。
  • boolean contains(Object o);查询集合中是否包括某个对象。
  • boolean containsAll(Collection c);查询该集合是否包括参数容器对象中所有对象。
  • Object[] toArray();
  • <T> T[] toArray(T[] a);

    删除方法:
  • boolean remove(Object o);
  • boolean removeAll(Collection c);用Set对象减去参数容器中对象,即差集,返回值用于确认集合是否改变。
  • boolean retainAll(Collection c);将参数容器与该Set对象做交集,即保留下共同内容,返回值用于确认集合是否改变。
  • void clear();

HashSet

HashSet底层用一个HashMap对象来存储内容,因此,可以说它是包装过的HashMap。也因此,HashSet和HashMap的构造函数类似,都可以使用初始容量initialCapacity和负载因子loadFactor对其初始化(对于HashSet,会在构造函数中对其所属的HashMap对象初始化)。同样的原因,对于Map中可以使用的方法,Set大多照旧。此外,由于HashMap对象的Entry需要key,value两个参数,而Set对象仅需要key参数来存储,系统会构建一个new Object()对象PRESENT来作为HashMap中Entry的value。

    private transient HashMap<E,Object> map;
private static final Object PRESENT = new Object();

可以说HashSet就是一个只用key存储的HashMap。

TreeSet

和HashSet类似,TreeSet底层也是用Map实现的,TreeSet类有两个成员对象:

    private transient NavigableMap<E,Object> m;
private static final Object PRESENT = new Object();

这里面用的NavigableMap我们学过Map后知道是TreeMap的上层接口,实际上还是一个TreeMap。

综上,在系统了解Map后学习Set,仅需要学习Set的使用即可。