**
# list集合框架:(Arraylist集合)
Arraylist集合有哪一些优势呢?
特有方法:List集合相对于collection父类集合来说有自己所特有的专属属性(索引)
对于list集合呢也还有一些新手可能出现的问题
这里是关于一些数组改变异常的一个方法
Arraylist子类强于父类的原因是自己有索引,可以通过下标进行一些操作以下是一些解释
list集合所特有的迭代器,ListIterator是Iterator的子接口
在迭代时,不可以通过集合对象的方法操作集合中的元素;
因为会发生并发修改异常(ConcurrentModificationException);
所以,在迭代时,只能通过迭代器来操作元素,课时Iterator的方法是有限的,Iterator只提供了判断、
取出、删除的操作;
如果想要有其他的操作,如添加、修改等,就需要使用其子接口ListIterator,该接口只能list集合的listIterator方法来获取
那么子类到底优于父类哪里呢?
我用图片进行了一些解释
说到了ArratList集合 那么就再说一下它的增长因子 以及优化问题我也用图片来更为详细的解释
Arraylist集合中还有Vector集合 那么Vector与list集合有什么区别呢?它有一个叫枚举的属性,其实与list集合特有迭代器差不多我这里就不详细解释了大家了解即可,它与list集合唯一不同的就是线程同步 且增长因子为2
而且ArrayList集合中还有一个链表结构的集合LinkedList链表集合并且,链表有两种数据储存方式,队列储存方式
我先遍历一个集合出来方便大家实验
下面我分别列出堆栈存储与队列存储
堆栈存储
以及队列存储
特有方法
addFirst();
addLast();
获取元素但是不删除元素,如果集合中没有元素,会出现NoSuchElementException
getFirst();
getLast();
获取元素的同时会删除元素,如果集合中没有元素,会出现NoSuchElementException
removeFirst();
removeLast();
在jdk1.6出现了替代方法
offerFirst()
offerLast()
peekFirst();
peekLast();
获取元素的同时会删除元素,如果集合中没有元素,会返回null
pollFirst();
pollLast();
由于是链表结构,当前节点能够记住上一个节点、以及下一个节点,所有有带First、last的方法存在。
所以我们可以这样比喻:
堆栈存储就好像一包纸
最先放进去的要最后面才出来
而队列存储就像在排队
先进先出
那么说了这么多
LIst集合中的ArrayList集合有一下特征
并且我再为大家列举一下它的一些方法
增
Add(index,element)
Add(index,Collection)
删
Remove(index)
改
Set(index,element)
查
Get(index)
subList(from,to)
listIterator()
index(element)
以下是我对与ArrayList集合的一下归纳,可能还有很多是错误的观点请大家指出来,谢谢大家
关于List集合中还有其他兄弟我会在后面一一讲解
**