解决线程安全问题_同步代码块和同步技术的原理
解决线程安全问题_同步代码块
解决线程安全问题的一种方案:使用同步代码块
格式:
synckroized(锁对象){
可能会出现线程安全问题的代码(访问了共享数据的代码)
}
注意:
1.通过代码块中的锁对象,可以使用任意的对象
2.但是必须保证多个线程使用的锁对象是同一个
3.锁对象作用:
把同步代码锁住,只让一个线程在同步代码块中执行
public class demg_07 implements Runnable{ //定义一个多线程共享的票源 private int ticket = 100; //创建锁对象 Object obj = new Object(); //设置线程任务:卖票 @Override public void run() { //使用死循环让卖票操作重复执行 while (true){ synchronized (obj){//同步代码块 //判断票是否存在 if (ticket > 0){ //提高安全问题出现的概率,让程序休眠 try { Thread.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } //票存在,卖票, ticket-- System.out.println(Thread.currentThread().getName()+"-->正在卖票"+ticket+"票"); ticket--; } } } } }
class a{ public static void main(String[] args) { //创建Runnable接口的实现对象 demg_07 d = new demg_07(); //创建Thread类对象,构造方法中传递Runnable接口的实现对象 Thread t1 = new Thread(d); Thread t2 = new Thread(d); Thread t3 = new Thread(d); //调用start方法开启线程 t1.start(); t2.start(); t3.start(); } }
运行结果:(使用同步代码块可以过滤重复的票和不存在的票)

同步技术的原理
同步技术的原理:
使用了一个锁对象,这个锁对象叫同步锁,也叫对象监视器
3个线程—起抢夺cpu的执行权谁抢到了谁执行run方法进行卖票
t0抢到了cpu的执行权执行run方法,遇到synchronized代码块这时t0会检查synchronized代码块是否有锁对象
发现有,就会获取到锁对象,进入到同步中执行
t1抢到了cpu的执行权执行run方法遇到synchronized代码块这时t1会检查synchronized代码块是否有锁对象
发现没有,t1就会进入到阻塞状态会一直等待t0线程归还锁对象一直到t0线程执行完同步中的代码会把锁对象归还给同步代码块,
t1才能获取到锁对象进入到同步中执行
总结:同步中的线程,没有执行完毕不会释放锁,同步外的线程没有锁进不去同步

浙公网安备 33010602011771号