多线程编程中,会出现多个线程同时访问
同一个
共享、可变资源的情况,这个资源我们称之其为
临界资源
;这种资源可以是:
对象
、
变量
、
文件
等。
- 共享:资源可以由多个线程同时访问
- 可变:资源在其生命周期内可以被修改
由于线程执行的过程是不可控的,所以需要采用同步机制,对对象的可变状态进行访问 。实际上,所有的并发模式在解决线程安全问题时,采用的方案都是 序列化访问临界资源
。即在同一时刻,只能有一个线程访问临界资源,也称作同步互斥访问
。
解决方式:
加锁 !!!
不过有一点需要区别的是:当多个线程执行一个方法时,该方法内部的局部变量并不是临界资源,因为这些局部变量是在每个线程的私有栈(工作内存)中,因此不具有共享性,不会导致线程安全问题。
Java 中,提供了两种方式来实现同步互斥访问:synchronized
和 Lock
,本文主要介绍 synchronized 锁。首先来了解一下 Java 中锁的分类吧。
1.锁的分类
锁ÿ