如何用Java编写代码来等待一个线程join()??

简介: 如何用Java编写代码来等待一个线程join()??

笔者在前面几篇文章中详细的讲解了:线程and进程的区别及其各种对比,如何中断一个线程等文章,接下来本篇文章主要讲解:用Java编写代码来等待一个线程join()??

线程之间是并发执行的,操作系统对于线程的调度是无序的,无法判断两个线程谁先执行结束,谁后执行结束~~

我们先来看一个案列吧:顺便猜一下到底是先输入“hello  main"还是先输出"hello t”呢??

public class Main {
    public static void main(String[] args) {
        Thread t=new Thread(()->{
            System.out.println("hello t");
        });
        t.start();
        System.out.println("hello main");
    }
}

那么,我们来看一下该段代码的运行结果:(多次刷新重新运行,会出现不一样的结果)

至于在前面所提到的:猜一下到底是先输入“hello  main"还是先输出"hello t”呢??这个是无法确定的~~

该段代码在实际执行的时候,大部分情况下都是先出“hello main"(因为线程的创建也有开销),但是不排除特定情况下,主线程的”hello main“没有立即执行到。程序猿是不喜欢不确定的!!有的时候需要明确规定线程的结束顺序----》可以用线程等待来实现(join()方法)

当我们在上述的代码中加入join()方法以后:

public class Main {
    public static void main(String[] args) throws InterruptedException {
        Thread t=new Thread(()->{
            System.out.println("hello t");
        });
        t.start();
        t.join();
        //是在main线程中调用t.join()
        //意思就是让main线程等待t先结束,再往下执行!!别的线程不受影响~
        System.out.println("hello main");
    }
}

该段代码的运行结果为:

在上述的代码中,我们再main线程里面加入了join()方法:

       t.join();

       是在main线程中调用t.join()

       意思就是让main线程等待t先结束,再往下执行!!别的线程不受影响~

如果是再t1线程中,加入t2.join(),就是让t1线程等待t2先结束,则t1进入阻塞,其他线程正常调度~

阻塞:Blocking:代码走到这一行就停下来,当前这个线程暂时不参与CPU的调度执行~

在上述的代码中:main阻塞了,不参与CPU的调度了,此时只有t去执行了,单个线程确实也谈不上并发不并发了~

  • main线程调用t.join()的时候,如果t还在运行,此时main线程阻塞,直到t执行完毕(t的run()执行完了),main才从阻塞中解除,才继续执行~
  • main线程调用t.join()的时候,如果t已经结束了,此时join()不会阻塞,就会立即往下执行

因此,我们可以得出:确保t是先结束的那个~~

其实对于join()还有另外一个版本:可以填写一个参数,作为”起始时间“;

  1. join()的无参数版本:效果是”死等“(不见不散)~
  2. join()的有参数版本:则是指定最大超时时间(很常见的设定),如果等待的时间到了上限,还没等到,也就不等了~
  3. 互相等待《--------》死锁了!Bug~
相关文章
|
16小时前
|
存储 监控 Java
如何在Java中实现等待文件修改后再读取数据的功能?
如何在Java中实现等待文件修改后再读取数据的功能?
4 0
|
18小时前
|
Java
如何解决使用若依前后端分离打包部署到服务器上后主包无法找到从包中的文件的问题?如何在 Java 代码中访问 jar 包中的资源文件?
如何解决使用若依前后端分离打包部署到服务器上后主包无法找到从包中的文件的问题?如何在 Java 代码中访问 jar 包中的资源文件?
5 0
|
1天前
|
存储 安全 Java
深入理解Java并发编程:线程安全与性能优化
【5月更文挑战第1天】本文将深入探讨Java并发编程的核心概念,包括线程安全和性能优化。我们将详细分析线程安全问题的根源,以及如何通过合理的设计和编码实践来避免常见的并发问题。同时,我们还将探讨如何在保证线程安全的前提下,提高程序的并发性能,包括使用高效的同步机制、减少锁的竞争以及利用现代硬件的并行能力等技术手段。
|
1天前
|
并行计算 Java 数据处理
Java中的多线程编程:基础知识与实践
【5月更文挑战第1天】本文将深入探讨Java中的多线程编程,包括其基本概念、实现方式以及实际应用。我们将从理论和实践两个角度出发,详细解析线程的创建、启动、控制以及同步等关键问题,并通过实例代码演示如何在Java中有效地使用多线程。
|
1天前
|
Java 程序员
Java中的多线程编程:从理论到实践
【5月更文挑战第1天】 在现代计算机科学中,多线程编程是一个重要的概念,它允许程序员在同一程序中并行运行多个任务。Java作为一种广泛使用的编程语言,提供了一套丰富的多线程编程工具。本文将介绍Java中多线程编程的基本概念,包括线程的创建、启动、控制和同步,以及一些常见的多线程问题和解决方案。
|
1天前
|
存储 Java 程序员
Java中的多线程编程:基础知识与实践
【5月更文挑战第1天】在现代计算机科学中,多线程是一种重要的并行计算技术,允许多个执行流程并发运行。本文将深入探讨Java语言中的多线程编程,从基础概念到实际应用,帮助读者理解多线程的核心原理,并通过实例学习如何在Java中创建和管理线程。我们将涵盖线程的生命周期、同步机制以及如何利用高级类如Executor框架来优化多线程应用的性能。通过本文的学习,读者将具备设计和实现高效、稳定多线程Java应用程序的能力。
6 2
|
2天前
|
缓存 Java 调度
Java并发编程:深入理解线程池
【4月更文挑战第30天】 在Java并发编程中,线程池是一种重要的工具,它可以帮助我们有效地管理线程,提高系统性能。本文将深入探讨Java线程池的工作原理,如何使用它,以及如何根据实际需求选择合适的线程池策略。
|
2天前
|
Java Spring
Java 效率编码 必备插件 Lombok 让代码更优雅
该内容是一个关于Lombok插件的教程摘要:介绍了Lombok用于减少Java开发中的模板代码,提升效率;讲解了如何在IntelliJ IDEA中安装Lombok插件,以及在pom.xml中添加依赖;并提到了@Data注解能自动生成getter/setter、equals、hashCode和toString方法,@Slf4j注解自动处理日志,@Builder用于构建对象,以及@AllArgsConstructor和@NoArgsConstructor注解生成构造函数。还鼓励探索更多Lombok的注解用法。
|
2天前
|
Java 关系型数据库 测试技术
Java代码一键生成数据库文档(案例详解)
Screw是一个自动化数据库文档生成工具,能根据数据库表结构快速生成简洁、多格式(HTML、Word、Markdown)的文档,支持MySQL、MariaDB等多数据库。它使用Freemarker模板,允许用户自定义样式。依赖包括HikariCP数据库连接池和对应JDBC驱动。通过在Java代码或Maven插件中配置,可方便生成文档。示例代码展示了如何在测试用例中使用Screw。文档效果依赖于数据库中的表和字段注释。
|
2天前
|
NoSQL Java API
java一行代码实现RESTFul接口
Spring Data REST是构建在Spring Data之上的库,可自动将repository转换为REST服务,支持JPA、MongoDB、Neo4j、GemFire和Cassandra。无需手动创建Service和Controller层。要开始,需配置JPA数据源,创建实体类和Repository接口。快速实现REST接口,只需引入spring-boot-starter-data-rest Maven依赖,并在Repository接口上添加@RepositoryRestResource注解。