上次说了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集合是无须的,添加顺序和遍历顺序不一样