美文网首页
Java容器:Set

Java容器:Set

作者: CieloSun | 来源:发表于2017-07-02 14:54 被阅读0次

    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的使用即可。

    相关文章

      网友评论

          本文标题:Java容器:Set

          本文链接:https://www.haomeiwen.com/subject/wigncxtx.html