1、什么是线程安全?
线程安全概念:当多个线程访问某一个类(对象或方法)时,对象对应的公共数据区始终都能表现正确,那么这个类(对象或方法)就是线程安全的。
Java平台中,因为有内置锁的机制,每个对象都有锁的功能。Java虚拟机会为每个对象维护两个“池”
对于任意的对象objectX,objectX的Entry Set用于存储等待获取objectX这个锁的所有线程,也就是传说中的锁池。
objectX的Wait Set用于存储执行了objectX.wait()/wait(long)的线程,也就是等待池。
Synchronized(同步方法/代码块): 可以在任意类及方法上面加锁,而加锁的这段代码称为“互斥区”或者“临界区”。
通过锁来实现资源的排它性,从而实际目标代码段同一时间只会被一个线程执行,进而保证了目标代码段的原子性。这是一种以牺牲性能为代价换来的安全。
那么在某些特殊场景下,你就要抉择性能重要还是安全重要,从而采用不用的策略。
2 、案例演示
public class Thread001 extends Thread{
private int count = 10 ;
public synchronized void run(){ count-- ; System.out.println(this.currentThread().getName() + " count = "+ count); }
public static void main(String[] args) {
Thread001 ttt = new Thread001(); Thread t1 = new Thread(ttt,"t1"); Thread t2 = new Thread(ttt,"t2"); Thread t3 = new Thread(ttt,"t3"); Thread t4 = new Thread(ttt,"t4"); Thread t5 = new Thread(ttt,"t5"); t1.start(); t2.start(); t3.start(); t4.start(); t5.start(); } } |
总结:
当多个线程访问Thread001的run方法时,以排队的方式进行处理。
一个线程想要执行synchronized修饰的方法里的代码:
1、 尝试获得锁
2 、如果拿到锁,执行synchronized代码体内容;拿不到锁,这个线程就会进入“锁池”,不断的尝试获得这把锁,直到拿到为止,而且是多个线程同时去竞争这把锁。
那么“锁池”和“等待池”又有什么区别呢?
接下来.......
请关注我哦,马上来.......