集合总结

本文详细对比了Java中List、Set和Map三种集合的区别,包括它们对重复性和空值的处理方式、排序特性以及常用实现类。同时介绍了如何根据具体需求选择合适的集合类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

List、Set 和 Map 都是实现了 Collection 接口的接口。

List Vs Set Vs Map

1) 重复性

  • List 允许有重复元素。任何数量的重复元素都可以在不影响现有重复元素的值及其索引的情况下插入到 List。
  • Set 不允许重复。Set 以及所有实现了 Set 接口的类都不允许重复值的插入。
  • Map 以键值对的形式对元素进行存储。Map 不允许重复键但允许重复值

2) 空值

  • List 允许任意数量的空值
  • Set 最多允许一个空值的出现。
  • Map 只允许出现一个空键但允许任意数量的空值

3) 排序

  • List 及其所有实现类保持了每个元素的插入顺序
  • Set 中的元素都是无序的;但某些 Set 的实现类以某种顺序对其中的元素进行排序,比如 LinkedHashSet 按照元素的插入顺序进行排序。
  • Map 跟 Set 一样对元素进行无序存储,但其某些实现类对元素进行了排序。比如,TreeMap 依据键对其中的元素进行升序排序而 LinkedHashMap 则按照每个元素的插入次序进行排序。

4) 常用实现类

  • List:ArrayList、LinkedList 等等。
  • Set:HashSet、LinkedHashSet、TreeSet、SortedSet 等等。
  • Map:HashMap、TreeMap、WeakHashMap、LinkedHashMap、IdentityHashMap 等等。

什么时候使用 Java 里的 List、Set 和 Map?

1) 如果你的数据不允许有重复值,Set 是最适合的选择,因为其所有实现类都不允许有重复值。
2) 如果需要经常根据元素的索引值进行一些查询操作,那么 List(ArrayList)将是一个不错的选择。
3) 如果需要保留每个元素的插入次序,那么还是首选 List。

4) 如果你的数据需要进行 key - value 映射,那么就是 Map 了。

常用方法

List:

add();添加方法

Iterator<Student> it = stus.iterator(); 迭代器遍历

compareTo();排序

Map:

put();添加方法;

get(index);获取键值

keySet();键值集合



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值