java集合框架及其特点(List、Set、Queue、Map)

简介: java集合框架及其特点(List、Set、Queue、Map)

常见的集合以及他们的特点有哪些呢

java集合类主要由Collection和Map两个根接口派生出来的。

Collection派生了List,Set,Queue这三个子接口。

1、List代表有序可重复集合,可直接根据元素的索引来访问。
ArrayList:
  • 排列有序,可重复
  • 底层使用数组
  • 速度快,增删慢
  • 线程不安全
  • 容量不够时,ArrayList是当前容量*1.5+1
Vector:
  • 排列有序,可重复
  • 底层使用数组
  • 速度快,增删慢
  • 线程安全,效率低
  • 当容量不足时,Vector默认扩展一倍容量
LinkedList:
  • 排列有序,可重复
  • 底层使用双向循环链表数据结构
  • 查询速度慢,增删快,add()和remove()方法快
  • 线程不安全
2、Set代表无序不可重复集合,只能根据元素本身来访问。
HashSet:
  • 排列无序,不可重复
  • 底层使用Hash表实现
  • 存取速度快
  • 内部是HashMap
TreeSet:
  • 排列无序,不可重复
  • 底层使用二叉树实现
  • 排序存储
  • 内部是TreeMap的SortedSet
LinkedHashSet:
  • 采用hash表存储,并用双向链表记录插入顺序
  • 内部是LinkedHashMap
3、Queue是队列集合。

在两端出入的List,可以用数组或链表实现

4、Map代表的是存储key-value对的集合,可根据元素的key来访问value。
HashMap:
  • 键不可重复,值可重复
  • 底层哈希表
  • 线程不安全
  • 允许key值为null,value也可以为null
HashTable:
  • 键不可重复,值可重复
  • 底层哈希表
  • 线程安全
  • key、value都不允许为null
TreeMap:
  • 键不可重复,值可重复
  • 底层二叉树

线程安全的有Vector、HashTable。它们都使用 synchronized 关键字来实现线程安全。

相关文章
|
1月前
|
前端开发 Java
java中的Queue队列的用法
java中的Queue队列的用法
19 1
|
28天前
|
Java
java8中List对象转另一个List对象
java8中List对象转另一个List对象
37 0
|
3天前
|
存储 Java C++
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
17 0
|
25天前
|
Java
Java使用List去重的四中方式
Java使用List去重的四中方式
19 6
|
29天前
Cause: java.sql.SQLIntegrityConstraintViolationException: Column ‘id‘ in field list is ambiguous
Cause: java.sql.SQLIntegrityConstraintViolationException: Column ‘id‘ in field list is ambiguous
18 0
|
1月前
|
Java
JAVA——List中剔除空元素(null)的三种方法汇总
JAVA——List中剔除空元素(null)的三种方法汇总
|
Java Apache
Java 中 List 分片的 5 种方法!(5)
Java 中 List 分片的 5 种方法!(5)
249 0
Java 中 List 分片的 5 种方法!(5)
|
Java
Java 中 List 分片的 5 种方法!(4)
Java 中 List 分片的 5 种方法!(4)
373 0
Java 中 List 分片的 5 种方法!(4)
|
Java
Java 中 List 分片的 5 种方法!(3)
Java 中 List 分片的 5 种方法!(3)
498 0
Java 中 List 分片的 5 种方法!(3)
|
Java
Java 中 List 分片的 5 种方法!(2)
Java 中 List 分片的 5 种方法!(2)
352 0
Java 中 List 分片的 5 种方法!(2)