java多线程

xiaoxiao2021-02-28  116

线程死锁的四个必要条件: 1. 互斥条件:一个资源每次只能被一个进程使用。 2. 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。 3. 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。 4. 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。 关于JVM参考jvm 其中java堆区和方法区都是线程共享的 JMM的三大特性:可见性、有序性、原子性 可见性:volatile关键字保证了变量的内存可见性,使用volatile关键字修饰的变量可以快速刷新回主内存。但是volatile并不能保证指令执行的原子性。 有序性:为了提高性能,减少指令的停顿时间,程序执行时可能会进行指令重排序。JMM能保证串行语义的有序性,但没义务保证并发条件下语义的有序性。以下指令不能重排(Happen-Before规则) 程序顺序原则:一个线程内保证语义的串行性 volatile规则:volatile变量的写,先发生于读,保证volatile变量的可见性 锁规则:解锁(unlock)必然发生在随后的加锁前(lock) 传递性:A先于B,B先于C,那么A必然先于C 线程的start方法必须先于它的每一个动作 线程的所有操作优于线程的终结(Thread.join()) 线程的中断先于被中断线程的代码 对象的构造函数执行、结束,先于finalize()方法。

java线程池使用 参考java高并发程序设计 JSR-133文档

转载请注明原文地址: https://www.6miu.com/read-31013.html

最新回复(0)