【JAVA集合V-Set】

1.Set接口及底层源码

(1)Set接口说明

  • 无序(添加和取出的顺序不一致),没有索引
  • 不允许重复元素,所以最多包含一个null

(2)Set底层源码

在这里插入图片描述在这里插入图片描述

从上图可以看到Set接口继承Collection接口。

2.Set常用方法及遍历方式

(1)Set接口的常用方法
在这里插入图片描述
(2)遍历方式

同Collection的遍历方式一样,因为Set接口是Collection接口的子接口。

  • 可以使用迭代器
  • 增强for
  • 不能使用索引的方式来获取

简单代码如下:

  public static void main(String[] args) {
        Set set = new HashSet();
        
        set.add(1);
        set.add(2);
        set.add(3);
        set.add(4);
        
        //遍历方式一:使用迭代器iterator()
        Iterator iterator = set.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
        
        //遍历方式二:增强for
        for (Object o : set) {
            System.out.println((int)o);
        }

    }

3.简单练习

public class SetTest {

    public static void main(String[] args) {
        Set set = new HashSet();

        set.add(1);
        set.add(5);
        set.add(3);
        set.add(2);



        //1,无序(添加和取出的顺序不一致),没有索引

        //遍历方式一:使用迭代器iterator() 输出1 2 3 5
        Iterator iterator = set.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }

        System.out.println("=====================");
        //2,不允许重复元素,所以最多包含一个null
        set.add(null);
        set.add(null);//这里只会输出一个null


        //遍历方式二:增强for
        for (Object o : set) {
            System.out.println(o);
        }

        //3,<T> T[] toArray(T[] a);的使用.:将集合元素转化为数组
        //但是要求数组的类型必须是当前集合元素的父类型,向上转型
        //与Object[] toArray()的区别
        /*
        *  1,该方法允许
         * 精确控制输出数组的运行时类型,
         * 2,并且可能,
         * 在某些情况下,用于节省分配成本。
        *
        *
        *
        *
        * */
        Integer[] arr=new Integer[set.size()];
        Integer[] in = (Integer[]) set.toArray(arr);
        System.out.println(in.getClass());
//        for (Object object : in) {
//            System.out.println(object.getClass());
//        }

        Object[] objects1 = set.toArray();
        System.out.println(objects1.getClass());


        
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值