用线程加锁模拟红绿灯

本文回忆了作者在学习Java时通过多线程模拟红绿灯的题目,探讨了使用`synchronized`关键字的局限性,并指出使用`ReentrantLock`可以更好地实现线程间的定向通知,从而提高同步控制的灵活性。
摘要由CSDN通过智能技术生成

先吐槽一波
今天学习lock的时候突然想起来
大一学Java的时候有个题叫
用线程加锁模拟红绿灯
当时感觉挺傻的
红绿灯是按顺序执行的
为什么开三个线程让他们抢占cpu

现在想想可能老师的目的是让我们练习线程间的通讯的吧(强力帮老师圆回来)
当时要求用 synchronized 写

package com.nwk.sync;


import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 *
 * 线程间的定制话通线
 */
//第一步 创建资源类
class ShareResource {
   
    //定义标志位
    private int flag = 1;  // 1 AA     2 BB     3 CC
    public synchronized void print25()  {
   
        try {
   
            //判断
            while(flag != 1) {
   
                //等待
                this.wait();
            }
            //干活
            System.out.println("红灯亮");
            Thread.sleep(2500);
            System.out.println("红灯灭");
            //通知
            flag = 2; //修改标志位 2
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }


            this.notifyAll();

    }
    public synchronized void print15()  {
   

        try {
   
            while(flag != 2) {
   
                this.wait();
            }
            System.out.println("绿灯亮");
            Thread.sleep(1500);
            System.out.println("绿灯灭")</
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一叶一菩提魁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值