文档章节

并发编程实战 1.5. 等待线程终止-join()方法

火犀牛
 火犀牛
发布于 2016/05/10 22:43
字数 558
阅读 4
收藏 0

在一些情况下,我们需要等待线程的终止,再继续执行剩下的代码,为达到这个目的,可以使用Thread类中的join()方法。当一个线程对象的join()方法被调用时,调用它的线程被挂起,直到这个线程对象结束时。

范例: 加载两个资源,当两个资源全部加载完之后,输出主线程结束

资源一:

package com.rr.current2.c1_5_join.test;

import java.util.Date;
import java.util.concurrent.TimeUnit;

/**
 * Created by Isaac on 16-5-10.
 */
public class ResourceOne implements Runnable {

    @Override
    public void run() {
        System.out.printf("资源1 正在加载中... (%s)\r\n", new Date());
        try {
            TimeUnit.SECONDS.sleep(3);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.printf("资源1 加载完成!(%s)\r\n", new Date());
    }
}

资源二:

package com.rr.current2.c1_5_join.test;

import java.util.Date;
import java.util.concurrent.TimeUnit;

/**
 * Created by Isaac on 16-5-10.
 */
public class ResourceTwo implements Runnable {
    @Override
    public void run() {
        System.out.printf("资源2 正在加载中...(%s)\r\n", new Date());
        try {
            TimeUnit.SECONDS.sleep(4);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.printf("资源2 加载完成!(%s)\r\n", new Date());
    }
}

测试:

package com.rr.current2.c1_5_join.test;

import java.util.concurrent.TimeUnit;

/**
 * Created by Isaac on 16-5-10.
 * 范例: 加载两个资源,当两个资源全部加载完之后,输出主线程结束
 */
public class Test {
    public static void main(String[] args) {
        Thread one = new Thread(new ResourceOne());
        Thread two = new Thread(new ResourceTwo());
        System.out.println("主程序开始!");
        one.start();
        two.start();

        try {
            one.join();
            two.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("主程序结束!");
    }
}

结果:

主程序开始!
资源1 正在加载中... (Tue May 10 22:37:01 CST 2016)
资源2 正在加载中...(Tue May 10 22:37:01 CST 2016)
资源1 加载完成!(Tue May 10 22:37:04 CST 2016)
资源2 加载完成!(Tue May 10 22:37:05 CST 2016)
主程序结束!

只有当ResourceOne与ResourceTwo都执行完了之后,才会继续执行main()方法。

还有另外两种形式:join(long milliseconds) 与 join(long milliseconds, long nanos),线程可以不必等到调用线程运行终止,如果到达参数指定的时钟,它将继续执行!

 

© 著作权归作者所有

共有 人打赏支持
火犀牛
粉丝 0
博文 27
码字总数 12180
作品 0
海淀
程序员
Java并发编程初级篇(四):等待子线程终止

我们先看一个例子,在这个例子中你会发现主线程结束后,过了一段时间两个子线程才结束。 定义实现Runnable接口的线程类,模拟执行一定时间后结束。 定义主方法,启动两个子线程: 查看控制台...

阿拉德大陆的魔法师
2016/11/23
20
0
读书笔记之《Java并发编程的艺术》-并发编程基础

读书笔记部分内容来源书出版书,版权归本书作者,如有错误,请指正。 欢迎star、fork,读书笔记系列会同步更新 git https://github.com/xuminwlt/j360-jdk module j360-jdk-thread/me.j360....

Hi徐敏
2015/11/11
0
8
Java7中的Fork/Join框架,到底在什么情况下才会采用工作窃取算法?

在学习《Java 7并发编程实战手册.pdf》第五章时,有一段话让我思考很久都很难理解,测试结果也不准确和信服,还请大家指教。 “当你使用同步方法,调用这些方法(比如:invokeAll()方法)的任...

JarvisZhu
2016/11/19
547
1
Java多线程学习(五)线程间通信知识点补充

系列文章传送门: Java多线程学习(一)Java多线程入门 Java多线程学习(二)synchronized关键字(1) java多线程学习(二)synchronized关键字(2) Java多线程学习(三)volatile关键字 Ja...

一只蜗牛呀
04/16
0
0
python之多线程并发处理模块-threading

thread:多线程的底层支持模块,一般不建议使用; threading:对thread进行了封装,将一些线程的操作对象化,一般采用这种方法实现多线程编程 多线程实现有两种模式: 1.创建线程要执行的函数...

zhpfxl
2016/12/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

mysql 数据类型及占用字节数

数字类型 TINYINT                           1 字节 SMALLINT                          2 个字节 MEDIUMINT                         3 个字节...

会游泳的鱼_
40分钟前
3
0
高性能mysql:创建高性能的索引

性能优化简介 MySQL性能定义为完成某件任务所需要的时间量度,换句话说,性能即响应时间,这是一个非常重要的原则。我们通过任务和时间而不是资源来测量性能。数据库服务器的目的是执行SQL语...

背后的辛酸
55分钟前
4
0
HTTP get、post 中请求json与map传参格式

import java.io.IOException;import java.net.URI;import java.net.URISyntaxException;import java.nio.charset.Charset;import java.util.ArrayList;import java.util.List;im......

寒风中的独狼
今天
3
0
IDEA中tomcat启动慢 耗时10分钟

用idea中的tomcat以debug模式启动,会非常的慢,而正常启动没啥问题;原因是debug模式中View Breakpoints断点代码,断点的是jar包,而现在启动由于jar包发生变化,导致启动时一直处于等待中。...

GoodMarver
今天
5
0
Linux学习-10月18(awk)

9.6/9.7 awk 一、awk简介   1. awk是一种编程语言,用于对文本和数据进行处理的   2. 具有强大的文本格式化能力   3. 利用命令awk,可以将一些文本整理成为我们想要的样子   4. 命令awk...

wxy丶
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部