当前位置:首页 > 科技  > 软件

掌握这四种方法,多线程按序执行不再是问题

来源: 责编: 时间:2024-06-27 17:20:27 220观看
导读目录在子线程中通过join()方法指定顺序在主线程中通过join()方法指定顺序通过倒数计时器CountDownLatch实现通过创建单一化线程池newSingleThreadExecutor()实现在子线程中通过join()方法指定顺序通过join()方法使当

目录

  • 在子线程中通过join()方法指定顺序
  • 在主线程中通过join()方法指定顺序
  • 通过倒数计时器CountDownLatch实现
  • 通过创建单一化线程池newSingleThreadExecutor()实现

在子线程中通过join()方法指定顺序

通过join()方法使当前线程“阻塞”,等待指定线程执行完毕后继续执行。51b28资讯网——每日最新资讯28at.com

举例:在线程thread2中,加上一句thread1.join(),其意义在于,当前线程2运行到此行代码时会进入阻塞状态,直到线程thread1执行完毕后,线程thread2才会继续运行,这就保证了线程thread1与线程thread2的运行顺序。51b28资讯网——每日最新资讯28at.com

public class ThreadJoinDemo {    public static void main(String[] args) throws InterruptedException {        final Thread thread1 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("打开冰箱!");            }        });         final Thread thread2 = new Thread(new Runnable() {            @Override            public void run() {                try {                    thread1.join();                } catch (InterruptedException e) {                    e.printStackTrace();                }                System.out.println("拿出一瓶牛奶!");            }        });         final Thread thread3 = new Thread(new Runnable() {            @Override            public void run() {                try {                    thread2.join();                } catch (InterruptedException e) {                    e.printStackTrace();                }                System.out.println("关上冰箱!");            }        });         //下面三行代码顺序可随意调整,程序运行结果不受影响,因为我们在子线程中通过“join()方法”已经指定了运行顺序。        thread3.start();        thread2.start();        thread1.start();     }}

运行结果:51b28资讯网——每日最新资讯28at.com

打开冰箱!拿出一瓶牛奶!关上冰箱!

在主线程中通过join()方法指定顺序

简单说一下子线程与主线程的区别,子线程指的是发生在Thread内部的代码,主线程指的是发生在main函数中的代码,我们可以在main函数中通过join()方法让主线程阻塞等待以达到指定顺序执行的目的。51b28资讯网——每日最新资讯28at.com

public class ThreadMainJoinDemo {    public static void main(String[] args) throws InterruptedException {        final Thread thread1 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("打开冰箱!");            }        });         final Thread thread2 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("拿出一瓶牛奶!");            }        });         final Thread thread3 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("关上冰箱!");            }        });         thread1.start();        thread1.join();        thread2.start();        thread2.join();        thread3.start();    }}

输出结果:51b28资讯网——每日最新资讯28at.com

打开冰箱!拿出一瓶牛奶!关上冰箱!

通过倒数计时器CountDownLatch实现

CountDownLatch通过计数器提供了更灵活的控制,只要检测到计数器为0当前线程就可以往下执行而不用管相应的thread是否执行完毕。51b28资讯网——每日最新资讯28at.com

public class ThreadCountDownLatchDemo {     private static CountDownLatch countDownLatch1 = new CountDownLatch(1);     private static CountDownLatch countDownLatch2 = new CountDownLatch(1);     public static void main(String[] args) {        final Thread thread1 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("打开冰箱!");                countDownLatch1.countDown();            }        });         final Thread thread2 = new Thread(new Runnable() {            @Override            public void run() {                try {                    countDownLatch1.await();                    System.out.println("拿出一瓶牛奶!");                    countDownLatch2.countDown();                } catch (InterruptedException e) {                    e.printStackTrace();                }            }        });         final Thread thread3 = new Thread(new Runnable() {            @Override            public void run() {                try {                    countDownLatch2.await();                    System.out.println("关上冰箱!");                } catch (InterruptedException e) {                    e.printStackTrace();                }            }        });         //下面三行代码顺序可随意调整,程序运行结果不受影响        thread3.start();        thread1.start();        thread2.start();    }}

输出结果:51b28资讯网——每日最新资讯28at.com

打开冰箱!拿出一瓶牛奶!关上冰箱!

通过创建单一化线程池newSingleThreadExecutor()实现

单线程化线程池(newSingleThreadExecutor)的优点,串行执行所有任务。51b28资讯网——每日最新资讯28at.com

public class ThreadPoolDemo {    static ExecutorService executorService = Executors.newSingleThreadExecutor();     public static void main(String[] args) {        final Thread thread1 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("打开冰箱!");            }        });         final Thread thread2 =new Thread(new Runnable() {            @Override            public void run() {                System.out.println("拿出一瓶牛奶!");            }        });         final Thread thread3 = new Thread(new Runnable() {            @Override            public void run() {                System.out.println("关上冰箱!");            }        });        executorService.submit(thread1);        executorService.submit(thread2);        executorService.submit(thread3);        executorService.shutdown();        //使用完毕记得关闭线程池    }}

输出结果:51b28资讯网——每日最新资讯28at.com

打开冰箱!拿出一瓶牛奶!关上冰箱!

51b28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-96998-0.html掌握这四种方法,多线程按序执行不再是问题

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Library Cache Hash Bucket与共享池闩锁争用问题

下一篇: Python自动化:适合新手练习的五个有趣又实用的Python脚本,帮你快速掌握编程技能!拿走不谢!

标签:
  • 热门焦点
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 使用AIGC工具提升安全工作效率

    在日常工作中,安全人员可能会涉及各种各样的安全任务,包括但不限于:开发某些安全工具的插件,满足自己特定的安全需求;自定义github搜索工具,快速查找所需的安全资料、漏洞poc、exp
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein“利用市场支配力量强迫服装厂商与之签订独家
  • 得物宠物生意「狂飙」,发力“它经济”

    作者|花花小萌主近日,得物宣布正式上线宠物鉴别,通过得物App内的“在线鉴别”,可找到鉴别宠物的选项。通过上传自家宠物的部位细节,就能收获拥有专业资质认证的得物鉴
  • 东方甄选单飞:有些鸟注定是关不住的

    作者:彭宽鸿来源:华尔街科技眼‍‍‍‍‍‍‍‍‍‍东方甄选创始人俞敏洪带队的“7天甘肃行”直播活动已在近日顺利收官。成立后一
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 联想的ThinkBook Plus下一版曝光,键盘旁边塞个平板

    ThinkBook Plus 是联想的一个特殊笔记本类别,它在封面放入了一块墨水屏,也给人留下了较为深刻的印象。据有人爆料,联想的下一款 ThinkBook Plus 可能更特殊,它
Top