线程管理(六)等待线程的终结

简介:

等待线程的终结

在某些情况下,我们需要等待线程的终结。例如,我们可能会遇到程序在执行前需要初始化资源。在执行剩下的代码之前,我们需要等待线程完成初始化任务。

为达此目的, 我们使用Thread 类的join() 方法。当前线程调用某个线程的这个方法时,它会暂停当前线程,直到被调用线程执行完成。

在这个指南中, 我们将学习用初始化例子来使用这个方法。

准备

指南中的例子是使用Eclipse IDE 来实现的。如果你使用Eclipse 或者其他的IDE,例如NetBeans, 打开并创建一个新的java项目。

怎么做呢

按照这些步骤来实现下面的例子::

1.   创建一个类名为 DataSourcesLoader 并一定实现Runnable接口。


1 public class DataSourcesLoader implements Runnable {

2.   实现run()方法。 它写信息来表明它开始运行,然后睡眠4秒,最后再写信息表明它结束运行。


01 @Override
02 public void run() {
03 System.out.printf("Beginning data sources loading: %s\n",new Date());
04 try {
05     TimeUnit.SECONDS.sleep(4);
06 } catch (InterruptedException e) {
07     e.printStackTrace();
08 }
09     System.out.printf("Data sources loading has finished:%s\n",new Date());
10 }

3.   创建一个类名为 NetworkConnectionsLoader 并一定要Runnable接口。实现run()方法。它将与DataSourcesLoader类的run()方法一样,但是它会睡眠6秒。

4.   现在, 创建一个类名为 Main,包含 main()方法。


1 public class Main {
2 public static void main(String[] args) {

5.   创建一个 DataSourcesLoader 类对象并让线程运行它。


1 DataSourcesLoader dsLoader = new DataSourcesLoader(); Thread thread1 = new Thread(dsLoader,"DataSourceThread");

6.    创建一个 NetworkConnectionsLoader 类的对象并让线程运行它。


1 NetworkConnectionsLoader ncLoader = new NetworkConnectionsLoader();
2 Thread thread2 = new Thread(ncLoader,"NetworkConnectionLoad er");

7.    让2个线程对象都调用 start() 方法。


1 thread1.start();
2 thread2.start();

8.   2个线程都使用 join() 方法等待终结。 此方法可以抛出InterruptedException 异常, 所以要包含捕捉代码。


1 try {
2    thread1.join();
3    thread2.join();
4 } catch (InterruptedException e) {
5    e.printStackTrace();
6 }

9.   写一条信息表明程序结束。


1 System.out.printf("Main: Configuration has been loaded: %s\n",new Date());

10. 运行程序并查看结果。

它是怎么工作的

当你运行这个程序时,你可以发现2个线程对象都开始他们的执行。首先, DataSourcesLoader 结束它的运行。然后, NetworkConnectionsLoader 类结束它的运行,同时,主线程对象继续运行并写下了最后的信息。

更多

Java 提供2种形式的 join() 方法:

  • join (long milliseconds)
  • join (long milliseconds, long nanos)

第一种join() 方法, 这方法让调用线程等待特定的毫秒数。例如,如果thread1对象使用代码thread2.join(1000), 那么线程 thread1暂停运行,直到以下其中一个条件发生:

  • thread2 结束运行
  • 1000 毫秒过去了

当其中一个条件为真时,join() 方法返回。

第二个版本的 join() 方法和第一个很像,只不过它接收一个毫秒数和一个纳秒数作为参数。 

目录
相关文章
|
6月前
|
安全 Java
【JavaSE专栏76】三态和五态,线程的不同状态:新建、运行、状态、阻塞、等待、计时等待状态
【JavaSE专栏76】三态和五态,线程的不同状态:新建、运行、状态、阻塞、等待、计时等待状态
|
6月前
|
Java 程序员 调度
如何用Java编写代码来等待一个线程join()??
如何用Java编写代码来等待一个线程join()??
20 0
|
1月前
|
存储 开发框架 安全
【C++ 线程】深入理解C++线程管理:从对象生命周期到线程安全
【C++ 线程】深入理解C++线程管理:从对象生命周期到线程安全
87 0
|
3月前
|
安全 Java 调度
线程学习(2)线程创建,等待,安全,synchronized(三)
线程学习(2)线程创建,等待,安全,synchronized(三)
26 0
|
3月前
|
安全 Java 调度
线程学习(2)线程创建,等待,安全,synchronized(二)
线程学习(2)线程创建,等待,安全,synchronized(二)
27 0
|
3月前
|
安全 Java 调度
线程学习(2)线程创建,等待,安全,synchronized(一)
线程学习(2)线程创建,等待,安全,synchronized(一)
40 0
|
6月前
|
Java 数据库
【JavaSE专栏79】线程死锁,多个线程被阻塞,等待彼此持有的资源
【JavaSE专栏79】线程死锁,多个线程被阻塞,等待彼此持有的资源
|
6月前
|
Java
线程等待唤醒(等待通知)机制
线程等待唤醒(等待通知)机制
19 0
|
7月前
|
Go
【Golang】goruntine 等待所有线程结束后执行
goruntine 等待所有线程结束后执行
|
9月前
|
Java Linux C++
java心法线程篇(1)——线程等待方法的异同
java心法线程篇(1)——线程等待方法的异同
72 1

相关实验场景

更多