上次说了Collection其中的一个子类List机器三个子类,今天就看看Collection的另一个子类Set接口,先看看源码中有哪些方法:

源码

public interface Set<E> extends Collection<E> {
   
    // Query Operations

    /** * *返回集合中元素的个数 */
    int size();

    /** * *判断集合是否为空 */
    boolean isEmpty();

    /** * * 判断传入参数在集合中是否存在 */
    boolean contains(Object o);

    /** * * 获取当前集合的迭代器,用于遍历集合 */
    Iterator<E> iterator();

    /** * * 将集合转为数组并返回,数组 */
    Object[] toArray();

    /** * *将集合中元素放入给定数组中,并返回此数组 */
    <T> T[] toArray(T[] a);


    // Modification Operations

    /** * * *向集合中添加元素,注意在向集合中添加元素时,集合中已经存在将要添加的元素时,则会添加失败 *集合中不允许有重复元素,但是在集合中的位置是不是有序的 */
    boolean add(E e);


    /** * * 如果存在指定的元素,则从该集合中删除 */
    boolean remove(Object o);

    /** * * *如果此集合包含指定集合的所有元素,则返回true, * 如果指定集合也是一个集合(如果该集合的子集),则返回true */
    boolean containsAll(Collection<?> c);

    /** * *如果尚不存在,则将指定集合中的所有元素添加到此集合中(可选操作)。如果指定的集合也是一个集合,则操作会有效地修改此集 *合,以使其值为两个集合中的如果在操作进行过程中修改了指定的集合,则此操作的行为是不确定的。 */
    boolean addAll(Collection<? extends E> c);

    /** * * *仅保留此集合中包含在指定集合中的元素(可选操作)。换句话说,从此集中删除指定集合中未包含的所有元素。 *如果指定的集合也是一个集合,则此操作会有效地修改此集合,以使其值为两个集合的交集 */
    boolean retainAll(Collection<?> c);

    /** * *从该集合中删除所有包含在指定集合中的元素(可选操作)。如果指定的集合也是一个集合,则此操作会有效地修改此集合, *以使其值为这两个集合的非相交 */
    boolean removeAll(Collection<?> c);

    /** * *从该集合中删除所有元素(可选操作)。此调用返回后,该集合将为空。 * */
    void clear();

    boolean equals(Object o);

    int hashCode();

    @Override
    default Spliterator<E> spliterator() {
   
        return Spliterators.spliterator(this, Spliterator.DISTINCT);
    }
}

总结

  • Set集合中不会出现重复元素
  • Set集合是无须的,添加顺序和遍历顺序不一样