目录:
线程状态及流转
锁类型
关键字:synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、优先级、
单例模式中的双重检查
死锁
线程通信
线程池
一些细节:在 线程/一些细节 里面
解决的实际问题:
各个平台的特殊点:
RxJava-Android
协程-Kotlin
isolate-Flutter
线程和进程的区别
线程状态及流转
join流程
Java锁类型
关键字:
synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、优先级、
单例模式中的双重检查 //www.greatytc.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