ArrayList 和 LinkedList 的的相同点和不同点分别是什么?
相同点:都是List接口的实现类,都有着List集合的特点 就是存储有序,允许重复 而且都不是线程安全的
不同点:ArrayList内部是数组 而LinkedList内部是双向链表
ArrayList和LinkedList的应用场景?
ArrayList的话内部是一个数组,查询元素的话还是比较方便的,给取对应的下标即可,但是插入元素的话会牵扯到数组的赋值移动
LinkedLisrt的话内部是一个双向链表,查询元素倒是不景气,需要向前或者向后进行遍历,但是增删元素只需要修改本元素的前后项即可
所以,ArrayList适合读多,LinkedList适合写多
ArrayList 和 LinkedList 都不是线程安全的,那有线程安全的 List 类吗?
线程安全 List 类有 Vector 和 CopyOnWriteList
Vector 是通过在其几乎所有方法前加 synchronized 关键字来保证线程安全性
CopyOnWriteList 则是通过数组复制的方法来保证线程安全的
既然 HashSet 是无序的,那么遍历 HashSet 时又是按照什么顺序输出的?
ArrayList是按照数组元素位置显示的
HashSet输出顺序并不是固定的,是由元素的哈希值和储存顺序决定的
Has