多线程之整体概括

Posted awkflf11

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程之整体概括相关的知识,希望对你有一定的参考价值。

 

11.Java并发:多线程和java.util.concurrent并发包总结

 

 

 

=====

 

11.Java并发:多线程和java.util.concurrent并发包总结

引言

前面已经针对Java多线程框架中具体的点介绍了很多了,现在是需要一个概括性总结的时候了,正好从网上找到一张描述java.util.concurrent包组成结构的类图,正好可以对java多线程中并发这块有一个概览性总结。

在转载别人的图之前先简要总结一下:

一、描述线程的类:Runable和Thread都属于java.lang包

二、内置锁synchronized属于jvm关键字,内置条件队列操作接口Object.wait()/notify()/notifyAll()属于java.lang包

二、提供内存可见性和防止指令重排的volatile属于jvm关键字

四、而java.util.concurrent包(J.U.C)中包含的是java并发编程中有用的一些工具类,包括几个部分:

1、locks部分:包含在java.util.concurrent.locks包中,提供显式锁(互斥锁和速写锁)相关功能;

2、atomic部分:包含在java.util.concurrent.atomic包中,提供原子变量类相关的功能,是构建非阻塞算法的基础;

3、executor部分:散落在java.util.concurrent包中,提供线程池相关的功能;

4、collections部分:散落在java.util.concurrent包中,提供并发容器相关功能;

5、tools部分:散落在java.util.concurrent包中,提供同步工具类,如信号量、闭锁、栅栏等功能;

以下图片转自:这里,文章标题是:深入浅出 Java Concurrency (1) : J.U.C的整体认识

技术分享图片

再次感谢画这张图的作者。

 
 
 
 
 

以上是关于多线程之整体概括的主要内容,如果未能解决你的问题,请参考以下文章

java 22 - 12 多线程之解决线程安全问题的实现方式1

多线程单例 可以概括为两中模式(饿汉模式和懒汉模式)

Java多线程系列--“JUC锁”02之 互斥锁ReentrantLock

多线程 之 线程池1

多线程之CompletableFuture全方面解析

多线程之CompletableFuture全方面解析