Java:深入List集合的可重复性和Set集合的不可重复性

本文探讨Java中List和Set集合对于元素重复性的处理。List如ArrayList允许元素重复,而Set如HashSet基于hashCode和equals方法判断元素唯一性。通过重写对象的hashCode和equals方法,可以自定义不重复性规则。然而,Set判断重复的依据是之前是否添加过,而非集合中已有相同元素,这可能导致意外的元素添加。
摘要由CSDN通过智能技术生成

在这里插入图片描述

Collection集合是单列集合,其下有两个分支,分别是List集合和Set集合。
List集合,可以存放重复的元素,比如其下的ArrayList集合。
Set集合,不可以存放重复的元素,比如其下的HashSet集合。
本文主要探讨这个“重复”针对的是什么。

先来准备一个Person类,下文将用Person对象作为集合元素。

public class Person {
   

    private int age;

    public Person(int age) {
   
        this.age = age;
    }

    public void setAge(int age) {
   
        this.age = age;
    }

    @Override
    public String toString() {
   
        return "Person{" + "age=" + age + '}';
    }
}

集合为了存放元素,一般使用add方法来追加元素,所以下面分析一下add方法。

List集合的可重复性

在ArrayList集合中,最基本的add方法的相关源码:

transient Object[] elementData; // 元素数组

private int size; // 元素数量

public boolean add(E e) {
   
    ensureCapacityInternal(size + 1); // 根据元素数量控制元素数组的容量
    elementData[size++] = e; // 元素数量加1,且新元素追加到元素数组中
    return true;
}

可以看出来,ArrayList集合在新增元素时,对新元素是否重复,没有任何相关的判定,直接就给新增了,符合了List集合的可重复性特征。

Set集合的不可重复性

在HashSet集合中,最基本的add方法的相关源码:

private transient HashMap<E,Object> map;

private static final Object PRESENT = new Object(); // 

public boolean add(E e) {
   
    return map.put(e, PRESENT) == null;
}

Set集合是单列集合,但在底层是用HashMap双列集合来实现,PRESENT属性仅仅为了拿来占用其中一列。

再看一下HashMap集合的

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rex Chou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值