JAVA多线程 JOIN

对于Java开发人员,多线程应该是必须熟练应用的知识点,特别是开发基于Java语言的产品。本文将深入浅出的表述Java多线程的知识点,在后续的系列里将侧重于Java5由Doug Lea教授提供的Concurrent并行包的设计思想以及具体实现与应用。
如何才能深入浅出呢,我的理解是带着问题,而不是泛泛的看。所以该系列基本以解决问题为主,当然我也非常希望读者能够提出更好的解决问题的方案以及提出更多的问题。由于水平有限,如果有什么错误之处,请大家提出,共同讨论,总之,我希望通过该系列我们能够深入理解Java多线程来解决我们实际开发的问题。
作为开发人员,我想没有必要讨论多线程的基础知识,比如什么是线程? 如何创建等 ,这些知识点是可以通过书本和Google获得的。本系列主要是如何理深入解多线程来帮助我们平时的开发,比如线程池如何实现? 如何应用锁等。
(1)方法Join是干啥用的? 简单回答,同步,如何同步? 怎么实现的? 下面将逐个回答。
自从接触Java多线程,一直对Join理解不了。JDK是这样说的:
join public final void join(long millis)throws InterruptedException Waits at most millis milliseconds for this thread to die. A timeout of 0 means to wait forever.
大家能理解吗? 字面意思是等待一段时间直到这个线程死亡,我的疑问是那个线程,是它本身的线程还是调用它的线程的,上代码:
package concurrentstudy;
/**
*
* @author vma
*/
public class JoinTest {
public static void main(String[] args) {
Thread t = new Thread(new RunnableImpl());
t.start();
try {
t.join(1000);
System.out.println("joinFinish");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class RunnableImpl implements Runnable {
@Override
public void run() {
try {
System.out.println("Begin sleep");
Thread.sleep(1000);
System.out.println("End sleep");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
结果是:
Begin sleep End sleep joinFinish
明白了吧,当main线程调用t.join时,main线程等待t线程,等待时间是1000,如果t线程Sleep 2000呢
public void run() {
try {
System.out.println("Begin sleep");
// Thread.sleep(1000);
Thread.sleep(2000);
System.out.println("End sleep");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
结果是:
Begin sleep joinFinish End sleep
也就是说main线程只等1000毫秒,不管T什么时候结束,如果是t.join()呢, 看代码:
public final void join() throws InterruptedException {
join(0);
}
就是说如果是t.join() = t.join(0) 0 JDK这样说的 A timeout of 0 means to wait forever 字面意思是永远等待,是这样吗?
其实是等到t结束后。
这个是怎么实现的吗? 看JDK代码:
/**
* Waits at most <code>millis</code> milliseconds for this thread to
* die. A timeout of <code>0</code> means to wait forever.
*
* @param millis the time to wait in milliseconds.
* @exception InterruptedException if any thread has interrupted
* the current thread. The <i>interrupted status</i> of the
* current thread is cleared when this exception is thrown.
*/
public final synchronized void join(long millis)
throws InterruptedException {
long base = System.currentTimeMillis();
long now = 0;
if (millis < 0) {
throw new IllegalArgumentException("timeout value is negative");
}
if (millis == 0) {
while (isAlive()) {
wait(0);
}
} else {
while (isAlive()) {
long delay = millis - now;
if (delay <= 0) {
break;
}
wait(delay);
now = System.currentTimeMillis() - base;
}
}
}
其实Join方法实现是通过wait(小提示:Object 提供的方法)。 当main线程调用t.join时候,main线程会获得线程对象t的锁(wait 意味着拿到该对象的锁),调用该对象的wait(等待时间),直到该对象唤醒main线程,比如退出后。
这就意味着main 线程调用t.join时,必须能够拿到线程t对象的锁,如果拿不到它是无法wait的,刚开的例子t.join(1000)不是说明了main线程等待1秒,如果在它等待之前,其他线程获取了t对象的锁,它等待时间可不就是1毫秒了。上代码介绍:
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package concurrentstudy;
/**
*
* @author vma
*/
public class JoinTest {
public static void main(String[] args) {
Thread t = new Thread(new RunnableImpl());
new ThreadTest(t).start();
t.start();
try {
t.join();
System.out.println("joinFinish");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class ThreadTest extends Thread {
Thread thread;
public ThreadTest(Thread thread) {
this.thread = thread;
}
@Override
public void run() {
holdThreadLock();
}
public void holdThreadLock() {
synchronized (thread) {
System.out.println("getObjectLock");
try {
Thread.sleep(9000);
} catch (InterruptedException ex) {
ex.printStackTrace();
}
System.out.println("ReleaseObjectLock");
}
}
}
class RunnableImpl implements Runnable {
@Override
public void run() {
try {
System.out.println("Begin sleep");
Thread.sleep(2000);
System.out.println("End sleep");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
在main方法中 通过new ThreadTest(t).start();实例化ThreadTest 线程对象, 它在holdThreadLock()方法中,通过synchronized (thread),获取线程对象t的锁,并Sleep(9000)后释放,这就意味着,即使main方法t.join(1000),等待一秒钟,它必须等待ThreadTest 线程释放t锁后才能进入wait方法中,它实际等待时间是9000+1000 MS
运行结果是:
getObjectLock Begin sleep End sleep ReleaseObjectLock joinFinish
小结:
本节主要深入浅出join及JDK中的实现。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# JAVA多线程之方法
# JOIN详解
# java
# JOIN
# java基本教程之join方法详解 java多线程教程
# java 中Thread.join()的使用方法
# Java之Thread的join方法实例
# java线程之join方法的使用介绍
# java多线程编程之join方法的使用示例
# Java多线程中关于join方法的使用实例解析
# Java使用join方法暂停当前线程
# Java字符串拼接新方法 StringJoiner用法详解
# 浅谈Java线程Thread.join方法解析
# java中join方法的理解与说明详解
# 多线程
# 深入浅出
# 是这样
# 这就
# 解决问题
# 结果是
# 开发人员
# 到该
# 有什么
# 我也
# 我想
# 带着
# 什么时候
# 之处
# 是怎么
# 请大家
# 它是
# 可以通过
# 希望能
# 可不
相关文章:
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何用AWS免费套餐快速搭建高效网站?
PHP 500报错的快速解决方法
如何选择网络建站服务器?高效建站必看指南
如何在搬瓦工VPS快速搭建网站?
建站之星各版本价格是多少?
如何用好域名打造高点击率的自主建站?
建站之星如何保障用户数据免受黑客入侵?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
,怎么用自己头像做动态表情包?
如何选择CMS系统实现快速建站与SEO优化?
如何在Windows服务器上快速搭建网站?
,网站推广常用方法?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
jQuery 常见小例汇总
C#如何在一个XML文件中查找并替换文本内容
网站制作公司排行榜,四大门户网站排名?
如何在阿里云服务器自主搭建网站?
Android使用GridView实现日历的简单功能
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
Swift开发中switch语句值绑定模式
如何快速上传建站程序避免常见错误?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何通过.red域名打造高辨识度品牌网站?
网站制作壁纸教程视频,电脑壁纸网站?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
建站之家VIP精选网站模板与SEO优化教程整合指南
建站之星如何优化SEO以实现高效排名?
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
如何用搬瓦工VPS快速搭建个人网站?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】
如何在Tomcat中配置并部署网站项目?
PHP正则匹配日期和时间(时间戳转换)的实例代码
北京建设网站制作公司,北京古代建筑博物馆预约官网?
如何快速搭建支持数据库操作的智能建站平台?
建站为何优先选择香港服务器?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
学校建站服务器如何选型才能满足性能需求?
北京制作网站的公司,北京铁路集团官方网站?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
如何规划企业建站流程的关键步骤?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
广州美橙建站如何快速搭建多端合一网站?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
如何配置WinSCP新建站点的密钥验证步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。