LIst集合(ArrayList)与父类的一些区别

**

# list集合框架:(Arraylist集合)

Arraylist集合有哪一些优势呢?

  1. 特有方法:List集合相对于collection父类集合来说有自己所特有的专属属性(索引)
    对于list集合呢也还有一些新手可能出现的问题LIst集合(ArrayList)与父类的一些区别_第1张图片
    这里是关于一些数组改变异常的一个方法

  2. Arraylist子类强于父类的原因是自己有索引,可以通过下标进行一些操作以下是一些解释LIst集合(ArrayList)与父类的一些区别_第2张图片
    list集合所特有的迭代器,ListIterator是Iterator的子接口

    • 在迭代时,不可以通过集合对象的方法操作集合中的元素;
    • 因为会发生并发修改异常(ConcurrentModificationException);
    • 所以,在迭代时,只能通过迭代器来操作元素,课时Iterator的方法是有限的,Iterator只提供了判断、
    • 取出、删除的操作;
    • 如果想要有其他的操作,如添加、修改等,就需要使用其子接口ListIterator,该接口只能list集合的listIterator方法来获取
  3. 那么子类到底优于父类哪里呢?
    我用图片进行了一些解释LIst集合(ArrayList)与父类的一些区别_第3张图片

  4. 说到了ArratList集合 那么就再说一下它的增长因子 以及优化问题我也用图片来更为详细的解释LIst集合(ArrayList)与父类的一些区别_第4张图片

  5. Arraylist集合中还有Vector集合 那么Vector与list集合有什么区别呢?它有一个叫枚举的属性,其实与list集合特有迭代器差不多我这里就不详细解释了大家了解即可,它与list集合唯一不同的就是线程同步 且增长因子为2
    LIst集合(ArrayList)与父类的一些区别_第5张图片

  6. 而且ArrayList集合中还有一个链表结构的集合LinkedList链表集合并且,链表有两种数据储存方式,队列储存方式

我先遍历一个集合出来方便大家实验LIst集合(ArrayList)与父类的一些区别_第6张图片
下面我分别列出堆栈存储与队列存储

堆栈存储

LIst集合(ArrayList)与父类的一些区别_第7张图片
以及队列存储
LIst集合(ArrayList)与父类的一些区别_第8张图片

特有方法

addFirst();

addLast();

 

获取元素但是不删除元素,如果集合中没有元素,会出现NoSuchElementException

getFirst();

getLast();

 

获取元素的同时会删除元素,如果集合中没有元素,会出现NoSuchElementException

removeFirst();

removeLast();

 

在jdk1.6出现了替代方法

offerFirst()

offerLast()

 

peekFirst();

peekLast();

 

获取元素的同时会删除元素,如果集合中没有元素,会返回null

pollFirst();

pollLast();



由于是链表结构,当前节点能够记住上一个节点、以及下一个节点,所有有带First、last的方法存在。
所以我们可以这样比喻:
堆栈存储就好像一包纸
最先放进去的要最后面才出来
而队列存储就像在排队
先进先出

那么说了这么多
LIst集合中的ArrayList集合有一下特征
LIst集合(ArrayList)与父类的一些区别_第9张图片
并且我再为大家列举一下它的一些方法

    • Add(index,element)
    • Add(index,Collection)
    • Remove(index)
    • Set(index,element)
    • Get(index)
    • subList(from,to)
    • listIterator()
    • index(element)

以下是我对与ArrayList集合的一下归纳,可能还有很多是错误的观点请大家指出来,谢谢大家
关于List集合中还有其他兄弟我会在后面一一讲解

**

你可能感兴趣的:(Java)