上好的集合类

本文详细介绍了Java集合框架中的Collection接口及其子接口List和Set,强调了它们的特性:List保持元素顺序且允许重复,Set则不允许重复并保持无序。此外,还探讨了Map接口及其实现类,Map用于存储键值对,键唯一,值可重复。文中还提及了遍历集合的不同方式,并讨论了对象相等性的概念,包括hashCode和equals方法的重要性。
摘要由CSDN通过智能技术生成

集合继承关系

 

Collection 接口有两个重要的子接口 List Set , 他们的实现子类都是单列集合
 Map 接口的实现子类 是双列集合,存放的 K-V

遍历方式

  1. 普通for循环

    for (int i = 0; i < list.size(); i++) {}

  2. 迭代器

    Iterator iterator = list.iterator();
    while (iterator.hasNext()) { 
        Object obj = iterator.next(); 
        System.out.println(obj); }

  3. 增强for循环(底层是迭代器)

    for (Object o : list) { }

LIST

List集合类中元素有序,添加顺序和取出顺序一致,而且可以重复,list集合中的每个元素都有 其对应的顺序索引,支持索引访问元素,从0开始

SET

Set:注重独一无二的性质,该体系集合可以知道某物是否已近存在于集合中,不会存储重复的元素

用于存储无序(存入和取出的顺序不一定相同)元素,值不能重复。不能通过索引访问

引用到堆上同一个对象的两个引用是相等的。如果对两个引用调用hashCode方法,会得到相同的结果,如果对象所属的类没有覆盖Object的hashCode方法的话,hashCode会返回每个对象特有的序号(java是依据对象的内存地址计算出的此序号),所以两个不同的对象的hashCode值是不可能相等的。

如果想要让两个不同的Person对象视为相等的,就必须覆盖Object继下来的hashCode方法和equals方法,因为Object hashCode方法返回的是该对象的内存地址,所以必须重写hashCode方法,才能保证两个不同的对象具有相同的hashCode,同时也需要两个不同对象比较equals方法会返回true

MAP

Map 保存具有映射关系的数据key-value,map中的key-value可以是任何引用类型的数据,key不允许重复,重复的添加具有相同的key的map元素是默认覆盖前面,value可以重复 key可以为null但是只能有一个,value也可以为null可以有多个,可以通过key找到对应的value

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值