高并发编程原理与实战.线程安全.锁原理.同步容器.实战之JAVA架构
Posted java889
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高并发编程原理与实战.线程安全.锁原理.同步容器.实战之JAVA架构相关的知识,希望对你有一定的参考价值。
1、什么叫容器?
-----》数组,对象,集合等等都是容器。
2、什么叫同步容器?
-----》Vector,ArrayList,HashMap等等。
3、在多线程环境下,为什么不用同步容器呢?
----》1、线程不安全问题。2、线程安全的情况下,但是性能非常差问题。
Vector(线程安全,基本不用)----》ArrayList(线程不安全)----》使用Collections.synchronizedList()将ArrayList转成线程安全(性能非常差,不常用)------》CopyOnWriteArrayList(并发容器,有读写分离的思想)
HashTable(线程安全,基本不用)----》HashMap(线程不安全)-----》使用Collections.synchronizedMap()将HashMap转成线程安全(性能非常差,不常用)-------》ConcurrentHashMap(并发容器,利用降低锁的力度,例如将一张大表分成多张小表,如果进行添加操作的时候,只需要锁一个小表,而不需要锁整张表,从而提高了效率)
Vector和ArrayList有什么区别呢?
-----》Vector是线程安全的,看源代码上,它的add方法和remove方法都是加上了synchronized,意味着是单线程执行的,起不了多线程的优势。ArrayList是线程不安全的,add和remove都没synchronized。
ArrayList不安全有什么影响?
------》有可能无法将值添加到同步容器中。
以上是关于高并发编程原理与实战.线程安全.锁原理.同步容器.实战之JAVA架构的主要内容,如果未能解决你的问题,请参考以下文章
Java并发编程原理与实战四十二:锁与volatile的内存语义
java并发编程:管程内存模型无锁并发线程池AQS原理与锁线程安全集合类并发设计模式