解决线程安全问题:同步方法

解决线程安全问题第二种方案:

同步方法

定义:用synchronized修饰的方法就叫做同步方法,保证一个线程执行该方法的时候,其它线程只能在方法外等着.
格式:
修饰符 synchronized 返回值类型 方法名(参数列表){
可能会产生线程安全问题的代码(访问了共享数据的代码)
}
代码实现:
实现类:

public class RunnableImpl implements Runnable{
    // 定义一个多线程贡献的票源
    private int ticket = 100;

    // 设置线程任务:卖票
    @Override
    public void run() {
        // 使用死循环,让卖票操作重复
        while (true) {`在这里插入代码片`
            payTicket();
        }
    }

    // 同步方法
    public synchronized void payTicket(){
        // 先判断票是否存在
        if (ticket > 0) {
            // 使用线程睡眠提高安全问题出现的概率
            try {
                Thread.sleep(10);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            // 卖票
            System.out.println("在卖" + Thread.currentThread().getName() + "线程的第:" + ticket + "张票");
            ticket--;
        }
    }
}

主方法(main方法):

public class Demo01Ticket {
    public static void main(String[] args) {
        // 创建实现类对象
        RunnableImpl runnable = new RunnableImpl();
        // 创建Thread类对象,构造方法中传递Runnable接口的实现类
        Thread thread0 = new Thread(runnable);
        Thread thread1 = new Thread(runnable);
        Thread thread2 = new Thread(runnable);
        // 调用start开启多线程
        thread0.start();
        thread1.start();
        thread2.start();
    }
}

重点代码:
在这里插入图片描述
同步方法的锁对象是谁?
在这里插入图片描述
同步方法的锁对象默认是实现类(new RunnableImpl()),也就是this.

那么静态方法是否可以同步?答案是肯定的.

静态同步方法

在这里插入图片描述
其实就是在同步方法的基础上增加了static关键字,但是其锁对象并不是this(实现类),因为this(实现类)是创建对象之后产生的,静态方法优先于对象.静态同步方法的锁对象是本类的class属性(class文件对象(反射)),相当于是这样的:
在这里插入图片描述

在这里插入图片描述
解决线程安全问题第一种方案:同步代码块
解决线程安全问题第三种方案:Lock锁

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值