Set接口是Java中一个用来存放对象容器,是一个无序、不可重复的集合,存放于java.util包中
HashSet 是 Set 接口的典型实现,大多数时候使用 Set 集合时都使用这个实现类。我们大多数时候说的set集合指的都是HashSet
HashSet 按照 Hash 算法来存储集合中的元素,因此具有很好的存取和查找性能
HashSet 具有以下特点:
①不能保证元素的排列顺序
②不可重复
③HashSet 不是线程安全的
④集合元素可以使 null
当向 HashSet 集合中存入一个元素时,HashSet 会调用该对象的 hashCode() 方法来得到该对象的 hashCode 值,然后根据hashCode 值决定该对象在 HashSet 中的存储位置。
首先需要导入Java中的java.util.HashSet包
import java.util.HashSet;
Set容器的定义
Set set=new HashSet();
//也可以使用泛型来限制元素的类型
Set<String> set=new HashSet<String>();
//我们一般推荐使用泛型
//也可以使用Object类
Set<Object> set=new HashSet<String>();
Set接口的一些重要的方法
set.add(1);
set.add("a");//添加元素
System.out.println(set);
set.remove(1);//移除元素
System.out.println(set);
set.clear();//清空集合
System.out.println(set);
set.add("a");
set.add("b");
set.add("c");
set.add("d");
set.add("d");//添加失败 set集合是不重复的
System.out.println(set);
//使用迭代器遍历集合
Iterator it=set.iterator();
System.out.println(it);
while(it.hasNext()) {
System.out.println(it.next());
}
//for each迭代集合
for(Object obj:set) {//把set的每一个值取出来 赋值给obj 直到循环set的所有值
System.out.println(obj);
}
System.out.println(set.size());//获得set的长度
TreeSet 是 SortedSet 接口的实现类,TreeSet 可以确保集合元素处于排序状态。
TreeSet 支持两种排序方法:自然排序和定制排序。默认情况下,TreeSet 采用自然排序。
Set<Integer> set=new TreeSet<Integer>();
set.add(5);
set.add(2);
set.add(4);
set.add(6);
set.add(1);
set.add(8);
System.out.println(set);
set.remove(2);
//判断集合中是否存在某个元素
System.out.println(set.contains(3));
//使用迭代器遍历集合
Iterator<Integer> it=set.iterator();
while(it.hasNext()) {
System.out.println(it.next());
}
//for each类型迭代
for(Object obj:set) {
System.out.println(obj);
}
需要注意的是,TreeSet必须使用同样类型的对象,否则会出现异常
结果的话大家可以copy到自己的集成开发环境中运行一下,多使用print方法查看结果,能够很快掌握Set集合以及TreeSet接口的使用方法