当前位置: 首页 > news >正文

双非本科准备秋招(19.2)—— 设计模式之保护式暂停

一、wait & notify

wait能让线程进入waiting状态,这时候就需要比较一下和sleep的区别了。

sleep vs wait        

1) sleep 是 Thread 方法,而 wait 是 Object 的方法

2) sleep 不需要强制和 synchronized 配合使用,但 wait 强制和 synchronized 一起用

3) sleep 时不会释放对象锁,但 wait 在等待的时候会释放对象锁

4) 它们在java中的状态不同 sleep是 TIMED_WAITING, wait是 WAITING

正确套路写法:

wait和notify搭配使用,一个线程需要满足条件时工作,一个线程负责提供条件后唤醒。

    synchronized (lock){
        while (条件不成立){
            lock.wait();
        }
        //条件成立,开始工作
    }
    //另一个线程
    synchronized (lock){
        lock.notifyAll();
    }

二、案例——保护式暂停 Guarded Suspension

        有一个结果需要从一个线程传递到另一个线程,让他们关联同一个 GuardedObject

        GuradObject类,提供get和product方法,按照wait和notify的套路写法即可。

        然后主线程创建一个实例对象(锁对象),用两个线程模拟的过程。

@Slf4j(topic = "c.test")
public class Guard {
    public static void main(String[] args) {
        GuardObject guardObject = new GuardObject();
        new Thread(() -> {
            log.debug("等待结果");
            Object o = guardObject.get();
            log.debug("结果:{}", o);
        }, "t1").start();

        new Thread(()->{
            log.debug("输出结果");
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            guardObject.product(10);
        }, "t2").start();
    }
}

class GuardObject{
    private Object response;

    public synchronized Object get(){
        while(response == null){
            try {
                this.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        return response;
    }

    public synchronized void product(Object response){
        this.response = response;
        this.notifyAll();
    }
}

2s以后,输出结果

三、超时优化

        可以改进一下GuardObject的方法,不要让t1一直空等,如果等了超过一定时间,那么就不等了。

        我们给get传个参数,作为最大等待时间timeoutbegin作为最初时间duration记录经历时间waitTime还需要等待的时间

class GuardObject{
    private Object response;

    public synchronized Object get(long timeout){
        long begin = System.currentTimeMillis();
        long duration = 0;
        while(response == null){
            long waitTime = timeout-duration;
            if(duration > timeout){
                break;
            }
            try {
                this.wait(waitTime);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            duration = System.currentTimeMillis() - begin;
        }
        return response;
    }

    public synchronized void product(Object response){
        this.response = response;
        this.notifyAll();
    }
}

2s可以返回结果,如果只等1s:

等3s:

四、join原理

        join的设计符合保护式暂停的设计模式。

    public final synchronized void join(long millis)
    throws InterruptedException {
        long base = System.currentTimeMillis();
        long now = 0;

        if (millis < 0) {
            throw new IllegalArgumentException("timeout value is negative");
        }

        if (millis == 0) {
            while (isAlive()) {
                wait(0);
            }
        } else {
            while (isAlive()) {
                long delay = millis - now;
                if (delay <= 0) {
                    break;
                }
                wait(delay);
                now = System.currentTimeMillis() - base;
            }
        }
    }

可以看到案例中超时优化代码和这里逻辑相同。

如果millis==0,代表需要一直wait,直到isAlive为假,也就是线程结束。

相关文章:

  • 每日一个脚本之一键部署Docker
  • 一、DataX简介
  • MCU+SFU视频会议一体化,视频监控,指挥调度(AR远程协助)媒体中心解决方案。
  • C/C++内存管理:new、delete功能及原理实现
  • redis-sentinel(哨兵模式)
  • Tkinter教程21:Listbox列表框+OptionMenu选项菜单+Combobox下拉列表框控件的使用+绑定事件
  • Redis持久化、主从与哨兵架构详解
  • C++入门
  • 嵌入式硬件工程师与嵌入式软件工程师
  • pycharm像jupyter一样在控制台查看后台变量
  • npm 下载报错
  • Spring和Spring Boot的区别
  • django实现外键
  • 四、OpenAI之文本生成模型(Text Generation)
  • 寒假作业-day11
  • KingSCADA实现按钮点击效果
  • 【Linux学习】线程互斥与同步
  • Python算法题集_二叉树的中序遍历
  • Vue3快速上手(三)Composition组合式API及setup用法
  • 【芯片设计- RTL 数字逻辑设计入门 15 -- 函数实现数据大小端转换】
  • 《水饺皇后》领跑五一档票房,《哪吒2》上座率仍居第一
  • 建设银行南昌分行引金融“活水”,精准灌溉乡村沃土
  • 比黄油年糕热量还高,这个火爆全网的甜品劝你慎吃
  • 国台办:相关优化离境退税政策适用于来大陆的台湾同胞
  • 最高法强化涉新就业形态民事案件审判指导:推动出台司法解释
  • 美国清洗政治:一幅残酷新世界的蓝图正在展开