`
kankan1218
  • 浏览: 276712 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

java join方法详解

阅读更多

 

    方法Join 是干啥用的? 简单回答,同步,如何同步? 怎么实现的? 下面将逐个回答。

   自从接触Java 多线程,一直对Join 理解不了。JDK 是这样说的:join public final void joinlong millisthrows 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) ; // 主线程只等1 秒,不管子线程什么时候结束
            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)  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 的锁,并Sleep9000 )后释放,这就意味着,即使
main
方法t.join(1000), 等待一秒钟,它必须等待
ThreadTest   线程释放t 锁后才能进入wait 方法中,它实际等待时间是9000+1000 MS
运行结果是:
getObjectLock
Begin sleep
End sleep
ReleaseObjectLock
joinFinish

 

分享到:
评论

相关推荐

    java基本教程之join方法详解 java多线程教程

    【Java多线程教程】- join方法深度解析 在Java多线程编程中,`join()`方法是一个关键的同步工具,它允许一个线程(通常为主线程)等待另一个线程(子线程)执行完毕后再继续执行。本文将详细探讨`join()`方法的原理...

    Java多线程详解

    以上是对"Java多线程详解"主题的详细阐述,涵盖了Java多线程的基本概念、实现方式、线程控制、线程池、并发集合、线程间通信以及并发编程中常见的问题和解决方案。学习和熟练掌握这些内容对于开发高效的多线程Java...

    JAVA多线程之方法 JOIN详解及实例代码

    Java中的`join()`方法是多线程编程中的一个重要特性,用于控制线程间的协作和同步。在Java中,多线程允许程序同时执行多个任务,但有时我们需要确保某些线程按照特定顺序完成,或者主线程需要等待其他线程执行完毕后...

    Java多线程join方法实例代码

    Java多线程join方法实例代码 ...* Java多线程join方法详解:https://www.cnblogs.com/itech/archive/2012/07/20/2598162.html * Java多线程编程基础:https://www.runoob.com/java/java-multithreading.html

    Java案例详解1精通Java项目开发

    在本Java案例详解1精通Java项目开发中,我们将深入探讨如何使用Java技术构建高效、稳定的企业信息系统。这个案例主要基于Java编程语言,并结合SQL2000数据库管理系统,利用MyEclipse开发工具来实现。以下将详细介绍...

    Mysql之innerjoin,leftjoin,rightjoin详解.pdf

    Mysql 之 inner join、left join、right join 详解 Mysql 中的连接查询是指从多个表中检索数据,并将它们组合成一个结果集。inner join、left join 和 right join 是 Mysql 中三种最常用的连接查询方式。 inner ...

    基于Solr的多表join查询加速方法

    本文将围绕"基于Solr的多表join查询加速方法"这一主题,深入探讨如何在Solr中实现类似join的功能,并优化查询性能。 在Solr中模拟join操作通常有两种策略:嵌入式数据模型和外部数据源查询(ExternalFileField或...

    Java多线程详解(超详细)_狂神说笔记完整版_项目代码_适合小白随课程学习

    Java多线程详解 在Java编程中,多线程是一种重要的技术,它使得程序能够同时执行多个任务,提高系统的效率和响应性。本教程将详细讲解Java中的多线程概念,包括线程的创建、状态、同步以及高级主题,旨在帮助初学者...

    java+多线程+同步详解源码整理

    Java的`Thread`类提供了控制线程的方法,如`start()`启动线程,`join()`等待线程结束,`sleep()`使线程暂停执行等。 3. **线程同步** 在多线程环境中,数据共享可能导致数据不一致,为了解决这个问题,Java提供了...

    Java 线程详解

    Java 线程详解 在 Java 编程语言中,线程是一种基本的编程单元,它允许开发者在一个程序中执行多个任务。线程是轻量级的进程,它可以与其他线程共享同一个进程的资源。线程的使用可以提高程序的效率和响应速度。 ...

    JAVA WEB 开发详解:XML+XSLT+SERVLET+JSP 深入剖析与实例应用.part2

    6.6.4 sendredirect()和forward()方法的区别 238 6.7 小结 239 第7章 web应用程序的部署 240 7.1 配置任意目录下的web应用程序 240 7.2 war文件 242 7.3 tomcat中servlet的另一种运行方式 244 7.4 与servlet...

    Java分支与合并框架详解.pdf

    `fork()`方法用于启动子任务,`join()`方法用于等待子任务完成并获取结果。 ```java public class ForkJoinSumCalculator extends RecursiveTask&lt;Long&gt; { // ... @Override protected Long compute() { // ... ...

    Java实现搜索功能代码详解

    Java实现搜索功能代码详解 Java实现搜索功能代码详解是一篇详细介绍了Java实现搜索功能代码的文章,主要讲解了如何使用Java语言实现搜索功能的详细思路和代码实现。下面我们将详细介绍其中的知识点。 搜索框的GET...

    java 中Thread.join()的使用方法

    在Java编程语言中,`Thread.join()`方法是一个非常重要的同步工具,它允许一个线程(调用者)等待另一个线程(被调用者)执行完成。`Thread.join()`的使用能够有效地解决多线程环境中的顺序执行问题,确保线程间的...

    java线程知识详解

    这些状态之间的转换由JVM和线程的执行情况决定,如join()方法可以使当前线程等待目标线程结束,wait()和sleep()方法可以使线程进入等待或阻塞状态。 Java提供了多种线程同步机制,以防止数据竞争和死锁的发生。...

    java多线程详解

    【Java多线程详解】 Java 多线程是Java编程中不可或缺的一部分,它允许程序同时执行多个任务,提高系统的效率和响应性。在Java中,多线程的实现主要有两种方式:继承`Thread`类和实现`Runnable`接口。 1. 继承`...

    java 多线程详解

    join()方法允许一个线程等待另一个线程完成。这样可以确保线程按照一定的顺序执行,防止数据竞争。 7. sleep()和yield() sleep()方法让当前线程暂停指定的时间,然后恢复执行。yield()方法则让当前线程放弃CPU...

    Java线程之join_动力节点Java学院整理

    Java线程之join方法详解 Java线程之join方法是Java中的一种线程同步机制,它允许一个线程等待另一个线程的完成。join方法定义在Thread.java中,通过源码分享join方法,需要的朋友可以参考以下内容。 join方法的...

Global site tag (gtag.js) - Google Analytics