黑马程序员_日记41_HashSetDemo

来源:互联网 发布:淘宝开店注意事项 编辑:程序博客网 时间:2024/04/30 04:12

 ——- android培训、java培训、期待与您交流! ———-

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,
重复元素是添加不进去的!

0 0
原创粉丝点击