Set集其实就是一个不包含重复元素的 collection。
Set元素存取是无序的,就是说元素取出和存入的顺序不一致;
Set元素是不可以重复的,就是说Set元素具有唯一性。
Set和Collecion的功能是一样的。
Set常见的子类有:
HashSet和TreeSet。
HashSet的底层是哈希表,多线程实现是不同步的,这点要注意!
下面先演示一下HashSet。
1 创建一个哈希表
2 添加元素
3 添加重复元素
4 利用迭代器取出元素
5 观察元素取出的顺序
- import java.util.*;
- class HashSetDemo
- {
- public static void main(String[] args)
- {
- //1 创建一个哈希集合
- HashSet hs = new HashSet();
- //2 添加元素
- hs.add("num02");
- hs.add("num03");
- hs.add("num01");
- hs.add("num08");
- hs.add("num05");
- hs.add("num05");
- hs.add("num07");
- hs.add("num07");
- hs.add("num09");
- hs.add("num04");
- System.out.println("添加非重复元素:"+hs.add("num06"));
- System.out.println("添加重复元素:"+hs.add("num06"));
- //获取迭代器取出元素
- for(Iterator it = hs.iterator(); it.hasNext(); )
- System.out.println(it.next());
- }
- }
复制代码 运行结果:
因为add方法的返回值是boolean类型的,所以打印了true和false。
所以要注意:boolean add(obj)这个返回类型!
从运行结果来看,元素取出的顺序和存入的顺序是不一致的!
这就是Set所谓的元素存取是无序的!
千万不要混淆元素是无序的。
另外,通过运行结果也不难发现,元素是没有重复的。
因为当添加重复元素的时候,add返回值为false,
重复元素是添加不进去的!
|
|