【多线程:任务分配】喝茶例子

简介: 【多线程:任务分配】喝茶例子

【多线程:任务分配】喝茶例子

01.介绍

我们现在有一个任务是 喝茶,喝茶的前提是 必须完成:洗水壶(1min) 烧开水(15min) 洗茶壶(1min) 洗茶杯(2min) 拿茶叶(1min)

这时我们怎么分配任务才能使时间最短?

通过观察我们可以发现,洗水壶是烧开水的前提 除此之外其他的任务之间没有关系,故我们可以这样做 洗水壶 烧开水 烧开水其间可以进行 洗茶壶 洗茶杯 拿茶叶三个任务,故总耗时为16min

画图解释

02.代码

这里用秒表示分钟

import java.util.concurrent.CountDownLatch;

public class work1 {
    public static void main(String[] args) throws InterruptedException {
        q1();
    }
    private static void q1() throws InterruptedException {

        long start = System.currentTimeMillis();
        CountDownLatch countDownLatch = new CountDownLatch(2);

        Thread t1 = new Thread(()->{
            Sleeper.sleep(1);
            System.out.println("洗水壶一分钟\n");

            Sleeper.sleep(15);
            System.out.println("烧开水十五分钟\n");
            countDownLatch.countDown();
        });

        Thread t2 = new Thread(()->{

            Sleeper.sleep(1);
            System.out.println("洗茶壶一分钟\n");

            Sleeper.sleep(2);
            System.out.println("洗茶杯两分钟\n");

            Sleeper.sleep(1);
            System.out.println("拿茶叶一分钟\n");
            countDownLatch.countDown();
        });


        t1.start();
        t2.start();
        countDownLatch.await();
        long end = System.currentTimeMillis();
        System.out.println("总耗时:"+(end-start));
    }
}

结果

洗茶壶一分钟

洗水壶一分钟

洗茶杯两分钟

拿茶叶一分钟

烧开水十五分钟

总耗时:16060

解释

我们可以把程序(进程)理解为工厂,把cpu理解为指挥,把线程理解为员工,所以 对于这个程序 我们又两个线程 即有两个人 一个人负责洗水壶 烧开水 一个人负责 洗茶壶 洗茶杯 拿茶叶。

CountDownLatch类简单介绍

这个程序我想统计最终时间,但是确发现了一个问题,我需要等待t1 t2线程结束后才可以 进行统计,这里我用了CountDownLatch类,当然用t1.join t2.join与主线程同步也可以。

这个类的应用场景有两个

场景一:多个线程等待另一个

场景二:一个线程等待多个线程

很明显我们这里需要用的就是场景二,主线程等待 t1 t2线程,最终统计时间。

这个程序中CountDownLatch类用到的方法

构造方法:传递一个整数,代表初始值

countDown():每调用一次 初始值减一

await():在初始值为0时 才会进行其后面的代码 否则 不执行

目录
相关文章
|
弹性计算 运维 安全
带你读《云上自动化运维宝典》——万字长文带你了解 CloudOps自动化运维的奥秘,助力云上业务高效稳定运行(1)
带你读《云上自动化运维宝典》——万字长文带你了解 CloudOps自动化运维的奥秘,助力云上业务高效稳定运行(1)
682 1
假如要限制每个来访问的IP,每秒钟都不超过10次,应该如何设置?
假如要限制每个来访问的IP,每秒钟都不超过10次,应该如何设置?
968 0
|
8月前
|
移动开发 前端开发 开发者
React 音频播放控制组件 Audio Controls
本文介绍了如何使用React构建音频播放控制组件,涵盖HTML5 `<audio>`标签和React组件化思想的基础知识。针对常见问题如播放状态管理、进度条更新不准确及跨浏览器兼容性,提供了详细的解决方案和代码示例。同时,还总结了易错点及避免方法,如确保音频加载完成再操作、处理音频错误等,帮助开发者实现稳定且功能强大的音频播放器。
358 11
|
9月前
|
负载均衡 数据可视化 API
零门槛,即刻拥有DeepSeek-R1满血版
零门槛,即刻拥有DeepSeek-R1满血版
|
9月前
|
存储 移动开发 JavaScript
网页 HTML 自动播放下一首音乐
在 HTML5 中实现自动播放下一首音乐,通过管理音乐列表、操作音频元素和监听事件完成。创建包含多个音乐链接的列表,使用 `<audio>` 元素加载音乐,监听 `ended` 事件,在当前音乐结束时自动播放下一首。示例代码展示了如何使用 JavaScript 实现这一功能,确保无缝切换音乐。
|
Go
Golang语言基础数据类型之字符类型
这篇文章介绍了Go语言中的字符类型,包括字符概述、byte和rune类型的定义、转义字符的使用以及如何遍历字符串获取字符的示例。
145 0
|
开发框架 数据库 开发者
OOP有哪些应用场景
【7月更文挑战第17天】OOP有哪些应用场景
404 3
|
算法 数据可视化 数据挖掘
使用Python实现DBSCAN聚类算法
使用Python实现DBSCAN聚类算法
839 2
|
SQL 关系型数据库 MySQL
optimizer_switch优化法案详解
optimizer_switch优化法案详解
|
域名解析 弹性计算 Ubuntu
ubuntu 18.04 如何设置开机自动启动脚本
本文主要为大家介绍如何通过systemd来实现ubuntu 18.04系统开机自动运行脚本。
12688 0
ubuntu 18.04 如何设置开机自动启动脚本