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