Java并发编程之同步容器与并发容器详解
一、同步容器
1、Vector——>ArrayList
- vector 是线程(Thread)同步(Synchronized)的,所以它也是线程安全的;
- Arraylist是线程异步(ASynchronized)的,是不安全的;
2、Hashtable——>HashMap
- Hashtable是synchronized,这意味着Hashtable是线程安全的,多个线程可以共享一个Hashtable;
- HashMap是非synchronized,这意味着HashMap是非线程安全的;
3、Collections集合中——>synchronizedXXX
ArrayList<Object> list = new ArrayList<>(); Collections.synchronizedList(list); HashMap<Object, Object> map = new HashMap<>(); Collections.synchronizedMap(map); Set<Object> set = new HashSet<>(); Collections.synchronizedSet(set);
以synchronizedList为例:synchronizedList返回了SynchronizedList<>(list)),SynchronizedList又是一个内部静态类,该内部静态类中的add()、set()、get()等方法都在方法内部添加了synchronized关键字,如下图:
二、并发容器
1、CopyOnWriteArrayList
- 写操作高效率并发并且是线程安全的;
- 读操作无锁的ArrayList;
2、ConcurrentHashMap
- 是HashMap的一个线程安全的、支持高效并发的版本,使用了锁分段技术来保证线程安全;
到此这篇关于Java并发编程之同步容器与并发容器详解的文章就介绍到这了,更多相关java同步容器与并发容器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Spring Cloud 部署时使用 Kubernetes 作为注册中心和配置中
Spring Cloud Kubernetes提供了使用Kubernete本地服务的Spring Cloud通用接口实现,这篇文章主要介绍了Spring Cloud 部署时如何使用 Kubernetes 作为注册中心和配置中心,需要的朋友可以参考下2024-05-05
最新评论