Set集合
public interface Set<E>extends Collection<E>
Set集合中存储的是不包含存储顺序的集合(存储顺序无效)而且是不可以重复的(重复后自动会替换之前相同的数据内容)
Set集合常用方法
boolean add(E e)
如果 set 中尚未存在指定的元素,则添加此元素(可选操作)。
boolean addAll(Collection<? extends E> c)
如果 set 中没有指定 collection 中的所有元素,则将其添加到此 set 中(可选操作)。
void clear()
移除此 set 中的所有元素(可选操作)。
boolean contains(Object o)
如果 set 包含指定的元素,则返回 true。
boolean containsAll(Collection<?> c)
如果此 set 包含指定 collection 的所有元素,则返回 true。
boolean equals(Object o)
比较指定对象与此 set 的相等性。
int hashCode()
返回 set 的哈希码值。
boolean isEmpty()
如果 set 不包含元素,则返回 true。
Iterator iterator()
返回在此 set 中的元素上进行迭代的迭代器。
boolean remove(Object o)
如果 set 中存在指定的元素,则将其移除(可选操作)。
boolean removeAll(Collection<?> c)
移除 set 中那些包含在指定 collection 中的元素(可选操作)。
boolean retainAll(Collection<?> c)
仅保留 set 中那些包含在指定 collection 中的元素(可选操作)。
int size()
返回 set 中的元素数(其容量)。
Object[] toArray()
返回一个包含 set 中所有元素的数组。
T[]
toArray(T[] a)
返回一个包含此 set 中所有元素的数组;返回数组的运行时类型是指定数组的类型。
Set集合的常用实现类
HashSet
TreeSet
HashSet
不保证迭代顺序,可以存储null,但是不能重复,此类实现是异步的,线程不安全的(效率高)
构造方法
方法 | 描述 |
---|---|
public HashSet() | 构造一个新的空 set,其底层 HashMap 实例的默认初始容量是 16,加载因子是 0.75 |
public HashSet(Collection<? extends E> c) | 构造一个包含指定 collection 中的元素的新 set |
创建一个Set对象
package com.scy.demo;
import java.util.*;
/**
* 创建一个Set集合对象
* @author gqk
*
*/
public class NewSetDemo {
public static void main(String[] args) {
List list = new ArrayList();
list.add("123");
list.add("安佳");
Set set = new HashSet();//创建一个空的Set集合对象
Set set2 = new HashSet(list);
System.out.println(set2);
}
}
常用api
除了一下的方法和重写过Set集合中的方法 还会去继承Set集合中public修饰的方法
boolean add(E e)
如果此 set 中尚未包含指定元素,则添加指定元素。
void clear()
从此 set 中移除所有元素。
Object clone()
返回此 HashSet 实例的浅表副本:并没有复制这些元素本身。
boolean contains(Object o)
如果此 set 包含指定元素,则返回 true。
boolean isEmpty()
如果此 set 不包含任何元素,则返回 true。
Iterator iterator()
返回对此 set 中元素进行迭代的迭代器。
boolean remove(Object o)
如果指定元素存在于此 set 中,则将其移除。
int size()
返回此 set 中的元素的数量(set 的容量)。
案例
package com.scy.demo;
import java.util.HashSet;
import java.util.