List和Set集合

List和Set集合

在这里插入图片描述

一、Collection

  • 定义
public interface Collection<E> extends Iterable<E>

java.util.Collection是进行单对象保存的最大父接口,即每次利用 Collection接口都只能保存一个对象信息。但是 Collection使用了泛型,这样可以保证集合中的数据类型统一。

  • 常用方法
编号方法名称描述
1boolean add(E e);向集合添加数据
2boolean addAll(Collection<? extends E> c);追加一个集合
3void clear();清空集合,根元素为null
4boolean contains(Object o);判断是否包含指定的内容,需要equals()支持
5boolean isEmpty();判断是否为空集合(不是null)
6boolean remove(Object o);删除对象,需要equals()支持
7int size();取得集合中保存的元素个数
8Object[] toArray();将集合变为对象数组保存
9Iterator iterator();为Iterator接口实例化(Iterator接口定义)

注意:contains()与remove()两个方法的操作时,必须保证类中了已经成功的覆写了 Object类中的 equals()方法,否则将无法正常完成操作

Collection接口存在一个问题,无法区分保存的数据是否重复,所以在开发中往往会使用两个子接口:ListSet子接口。List子接口保存的数据可以重复、是有顺序的Set去除重复元素,无序的,重复元素会覆盖掉 。

二、List

List的子类有 ArrayListLinkListVector。但是 Vector不常用,就不在阐述。

List子接口中保存的数据是可以重复的,并且在 Collection子接口中,List这个子接口是使用最多的。对 Collection接口的功能进行了扩充。

  • 扩充方法
编号方法名称描述
1E get(int index);根据索引获取数据
2E set(int index, E element);修改制定索引的数据
3ListIterator listIterator(int index);为ListIterator接口实例化

2.1、ArrayList和LinkList的区别

2.1.1、底层实现区别

  • ArrayList 底层实现就是数组,且ArrayList实现了RandomAccess,表示它能快速随机访问存储的元素,通过下标 index 访问,只是我们需要用 get() 方法的形式, 数组支持随机访问, 查询速度快, 增删元素慢;

  • LinkedList 底层实现是链表LinkedList 没有实现 RandomAccess 接口,链表支持顺序访问, 查询速度慢, 增删元素快

  • ArrayList 定义

public class ArrayList<E> extends AbstractList<E>
        implements List<E>, RandomAccess, Cloneable, java.io.Serializable
  • LinkedList定义
public class LinkedList<E>
    extends AbstractSequentialList<E>
    implements List<E>, Deque<E>, Cloneable, java.io.Serializable

注意:这个问题面试问到的几率十分高

2.1.2、应用场景不同

ArrayList应该在需要更多搜索操作的地方使用,并且LinkedList应该在需要更多插入和删除操作的地方使用。

三、Set

Set的常用的子类有 HashSet<E>TreeSet<E>

HashSet是三列存放数据,TressSet是有序存放数据。在开发中,如果使用 TressSet子类,必须同时使用比较器的概念。HashSet子类相对于 TressSet子类容易一些,所以没有排序要求的,首先考虑 HashSet子类。

四、List和Set的区别

1、List中元素放入是有顺序的,可以重复Set去除重复元素,无序的,重复元素会覆盖掉。

2、Set检索效率低,删除和插入效率高,插入和删除不会引起元素位置的改变;而List和数组类似,可以动态增长,查找效率高,插入和删除效率低,会引起元素位置的改变。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值