【java并发编程实战】第一章笔记

时间:2023-12-17 12:39:02

1.线程安全的定义

当多个线程访问某个类时,不管允许环境采用何种调度方式或者这些线程如何交替执行,这个类都能表现出正确的行为

如果一个类既不包含任何域,也不包含任何对其他类中域的引用。则它一定是无状态的对象,无状态对象一定是线程安全的

2.竞态条件

并发编程中,由于不恰当的执行时序导致不正确的结果。当某个计算结果的正确性取决于多线程交替执行时序时,就会发生竞态条件。

常见的竞态条件:

  • 先检查后执行。
  • 读取-修改-写入

3.复合操作

为了避免产生竞态条件,必须以原子的形式执行一组操作。

4.内置锁(监视器锁)

java提供了内置的原子性操作的锁机制:同步代码块(synchronize),它包含两部分,一个作为锁的对象引用。一个作为由这个锁保护的代码块。每个java对象都是自带一个监视器锁。线程进入获取锁,出来释放锁。

  • 4.1 重入

定义:当某个线程请求由其他线程持有的锁时,就会发生堵塞。但是内置锁是可以重入的,当该线程尝试或的锁是已经由自己持有的,那么该请求就会成功。重入意味着 锁的粗粒度是线程而非调用

如下代码,如果内置锁不可重入,下面的代码就会发生死锁。

public class SynchronizeTest extends superSynchronize {

    @Override
public synchronized void superMethod1() {
System.out.println("synchronized test ");
super.superMethod1();
} public static void main(String[] args) {
new SynchronizeTest().superMethod1();
}
} class superSynchronize { public synchronized void superMethod1() {
System.out.println("superMethod1 sybchronized");
} }