同步技术的原理:
使用一个锁对象,这个锁对象叫同步锁,也叫对象锁,也叫对象监视器.
程序中我们创建三个线程(t0、t1、t2),这三个线程同时抢夺cpu的执行权,谁抢到了谁就执行cpu的run方法.
1.t0抢到了cpu的执行权,执行run方法,而我们把同步代码块写在了run方法中,所以在执行run方法时会遇到synchronized代码块,这时t0会检查synchronized代码块是否有锁对象.发现有,就会获取到锁对象,进入到同步代码块中执行.
2.t1抢到了cpu的执行权,执行run方法,同样遇到了synchronized代码块,同样也会检查synchronized代码块是否有锁对象,然而锁对象被t0线程拿走了还未还回来.此时t1就进入到阻塞状态,会一直等待t0线程归还锁对象.等到t0执行完同步代码块中的代码,就会把锁对象还给同步代码块,t1才能获取到锁对象进入到同步代码块中执行.
3.t2线程同上(与t1一样,等待、获取、执行)
总结:
同步中的线程没有执行完毕不会释放锁,
同步外的线程没有获取锁进不去.
优点:
保证了只能有一个线程在同步中执行共享数据,保证了安全.
缺点:
程序频繁的判断锁、获取锁、释放锁,程序的效率会降低
解决线程安全问题第二种方法:同步方法