高并发编程原理与实战.线程安全.锁原理.同步容器.实战之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并发编程实战》第五章 同步容器类 读书笔记

Atitit.并发编程原理与概论 attilax总结

Java并发编程原理与实战四十二:锁与volatile的内存语义

java并发编程:管程内存模型无锁并发线程池AQS原理与锁线程安全集合类并发设计模式

java并发编程:管程内存模型无锁并发线程池AQS原理与锁线程安全集合类并发设计模式

java并发编程实战:第五章----基础构建模块