Java多线程——模拟看病叫号

需求说明:

某科室一天需看普通号50个,特需号10个

特需号看病时间是普通号的2倍

开始时普通号和特需号并行叫号,叫到特需号的概率比普通号高

当普通号叫完第10号时,要求先看完全部特需号,再看普通号

使用多线程模拟这一过程

思路:

这题如果把专家号和普通号都写为子线程就难了,

把专家号写成子线程,把普通号写成主线程这样就简单了,因为子线程和主线程是并行的,所以不会有任何的影响。

主线程:

java 复制代码
package KB;

public class kbTest {
    public static void main(String[] args) {
        // 专家号和普通号两个线程同时执行,普通号是主线程,专家号是子线程
        Lookbing lookbing = new Lookbing();
        Thread thread1 = new Thread(lookbing);

        // 叫到特需号的概率比普通号高
        thread1.setPriority(Thread.MAX_PRIORITY);
        Thread.currentThread().setPriority(Thread.MIN_PRIORITY);
        thread1.start();

        // 20个普通号
        for (int i = 1; i <= 50; i++) {
            System.out.println("普通号:"+i+"号病人正在看病");
            try {
                Thread.sleep(500);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            // 当普通号叫完第10号时,要求先看完全部特需号,再看普通号
            if(i==10){
                //
                try {
                    thread1.join();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

子线程:

java 复制代码
public class Lookbing implements Runnable{
    @Override
    public void run() {
        for (int i = 1; i <= 10; i++) {
            System.out.println("专家号:"+i+"号病人正在看病");
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

}
相关推荐
皮皮林5514 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
卡尔特斯8 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源8 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole8 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫8 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide9 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261359 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源9 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群10 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心10 小时前
从零开始学Flink:数据源
java·大数据·后端·flink