java25(集合框架--02 list)
Collection:
|-- List:元素是有序的,元素可以重复。因为该集合体系有索引
|-- ArrayList:底层的数据结构使用的是数组结构特点:查询快,增删改慢,线程不同步
|-- LinkedList:底层的数据结构使用的是链表数据结构特点:查询慢,增删改快
|-- Vector:底层的数据结构使用的是数组结构特点:线程同步,被ArrayList替代了
|-- Set:元素是无序的,元素不可以重复
|-- HashSet:底层的数据结构使用的是哈希表
|-- TreeSet:底层的数据结构使用的是二叉树,可以对set集合中的元素排序
List基本方法:
凡是可以操作角标的方法都是该体系特有的方法
增:
add(index,element);
addAll(index,Collection);
删:
remove(index);
改:
set(index,element);
查:
get(index);
subList(from,to);
ListIterator:
如下图例子所示,使用迭代器取出元素的同时,又使用集合追加元素会造成安全问题
data:image/s3,"s3://crabby-images/922c5/922c566a57ea7cbde2db104c8cae061b83491e9c" alt=""
对于以上的线程安全问题,我们可以使用List集合特有的迭代器:ListIterator
ListIterator是Iterator的子接口。该接口只能通过List集合的listIterator方法获取
data:image/s3,"s3://crabby-images/63d7d/63d7db9a58a518ae132fb54debee685f98eefa55" alt=""
Vector中的枚举:
枚举就是Vector特有的取出方式。跟迭代器很像,但是因为其名称与方法名称过长,慢慢被迭代器取代了
data:image/s3,"s3://crabby-images/0eebe/0eebe52bf38e6c0bdd6cd13097a5636f6fba3459" alt=""
LinkedList:
data:image/s3,"s3://crabby-images/17637/176371de9c8f54cd1e99dc671af9f093231d3bf0" alt=""
例:ArrayList存储对象:
data:image/s3,"s3://crabby-images/f3dc3/f3dc3d6be98d3bfce82bd35aae44c8d76b714dd8" alt=""
例:对象去重:
data:image/s3,"s3://crabby-images/a2f4c/a2f4ca4f3a0a0632e1acf8de6d541fecf54892f8" alt=""