Java多线程知识

目录:

线程状态及流转

锁类型

关键字:synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、优先级、

单例模式中的双重检查

死锁

线程通信

线程池

一些细节:在 线程/一些细节 里面

解决的实际问题:

各个平台的特殊点:

RxJava-Android

协程-Kotlin

isolate-Flutter

线程和进程的区别


线程状态及流转

image.jpeg

join流程

image.jpeg

Java锁类型

image.jpeg

关键字:

synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、优先级、

单例模式中的双重检查 https://www.jianshu.com/p/3b4f47c288ac

public class Singleton { private static volatile Singleton singletonInstance; // 静态属性,volatile保证可见性和禁止指令重排序 private Singleton () {} public static Singleton getInstance() { if(singletonInstance == null) { // 第一重检查锁定 synchronized(Singleton.class) // 同步锁定代码块 if(singletonInstance == null) // 第二重检查锁定 singletonInstance = new Singleton (); // 注意:非原子操作 } return singletonInstance; } }

死锁的四个条件:

互斥条件:一个资源每次只能被一个进程使用。

占有且等待:一个进程因请求资源而阻塞时,对已获得的资源保持不放。

不可强行占有:进程已获得的资源,在末使用完之前,不能强行剥夺。

循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁。

死锁的解除与预防:

理解了死锁的原因,尤其是产生死锁的四个必要条件,就可以最大可能地避免、预防和解除死锁。所以,在系统设计、进程调度等方面注意如何不让这四个必要条件成立,如何确定资源的合理分配算法,避免进程永久占据系统资源。此外,也要防止进程在处于等待状态的情况下占用资源。因此,对资源的分配要给予合理的规划。

线程通信/同步:锁解决

线程池 // TODO

CPU密集 vs IO密集:

CPU密集型任务应配置尽可能小的线程,如配置CPU数目个线程的线程池。

由于IO密集型任务线程并不是一直在执行任务,则应配置尽可能多的线程,如2*CPU数目。

1、FixedThreadPool

线程数固定的线程池,只有核心线程,不会回收空闲线程,任务队列没有大小限制。

2、CachedThreadPool

线程数量不定的线程池,只有非核心线程,最大线程数Integer.MAX_VALUE。如果没有空闲线程就new,空闲线程超时60秒,超时被回收。

3、ScheduledThreadPool

核心线程固定,非核心线程Integer.MAX_VALUE,非核心线程空闲时立刻回收。主要用于执行定时任务和固定周期的重复任务。

4、SingleThreadExecutor

只有一个核心线程,所有任务按顺序执行。

解决的实际问题:

线程池、interrupt终止线程、死锁

各个平台的特殊点:

RxJava-Android

协程-Kotlin

isolate-Flutter

Java 并发基础之内存模型: https://javadoop.com/post/java-memory-model

重排序

内存可见性

原子性

Happens-before Order

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。