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方法的理解与说明详解
# 多线程
# 深入浅出
# 是这样
# 这就
# 解决问题
# 结果是
# 开发人员
# 到该
# 有什么
# 我也
# 我想
# 带着
# 什么时候
# 之处
# 是怎么
# 请大家
# 它是
# 可以通过
# 希望能
# 可不
相关文章:
大连 网站制作,大连天途有线官网?
手机网站制作与建设方案,手机网站如何建设?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
c++怎么用jemalloc c++替换默认内存分配器【性能】
如何通过西部数码建站助手快速创建专业网站?
山东云建站价格为何差异显著?
香港服务器WordPress建站指南:SEO优化与高效部署策略
C++如何编写函数模板?(泛型编程入门)
建站之星图片链接生成指南:自助建站与智能设计教程
如何快速搭建高效服务器建站系统?
如何选择域名并搭建高效网站?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
平台云上自助建站如何快速打造专业网站?
测试制作网站有哪些,测试性取向的权威测试或者网站?
大同网页,大同瑞慈医院官网?
如何将凡科建站内容保存为本地文件?
海南网站制作公司有哪些,海口网是哪家的?
如何通过WDCP绑定主域名及创建子域名站点?
如何在IIS中新建站点并解决端口绑定冲突?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
网站按钮制作软件,如何实现网页中按钮的自动点击?
详解jQuery停止动画——stop()方法的使用
如何通过商城自助建站源码实现零基础高效建站?
公众号网站制作网页,微信公众号怎么制作?
网站制作公司排行榜,抖音怎样做个人官方网站
如何在云主机快速搭建网站站点?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何设置并定期更换建站之星安全管理员密码?
C#如何使用XPathNavigator高效查询XML
南京网站制作费用,南京远驱官方网站?
建站ABC备案流程中有哪些关键注意事项?
广州建站公司哪家好?十大优质服务商推荐
c# 在高并发下使用反射发射(Reflection.Emit)的性能
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
一键网站制作软件,义乌购一件代发流程?
学校为何禁止电信移动建设网站?
成都响应式网站开发,dw怎么把手机适应页面变成网页?
建站之星安装后界面空白如何解决?
网站制作软件有哪些,制图软件有哪些?
,如何利用word制作宣传手册?
微课制作网站有哪些,微课网怎么进?
如何快速使用云服务器搭建个人网站?
c# await 一个已经完成的Task会发生什么
建站之星如何快速更换网站模板?
*请认真填写需求信息,我们会在24小时内与您取得联系。