解决线程安全问题_同步代码块和同步技术的原理

解决线程安全问题_同步代码块

解决线程安全问题的一种方案:使用同步代码块

格式:

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才能获取到锁对象进入到同步中执行


总结:同步中的线程,没有执行完毕不会释放锁,同步外的线程没有锁进不去同步

 

posted @   monkey大佬  阅读(37)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示