java多线程join的使用?

这段代码是用于验证join方法的使用, 一个线程通过join方法等待另一个线程的执行结束, 按照我的理解, 应该是a和b有序输出, 且主线程一定在b输出之后输出. 但是实际运行结果并不是这样的. 实际的输出如下:
图片描述
书上讲不光会出现这种情况, 还有可能出现:

threadA sleep start , end

threadB sleep start

main end

threadB sleep end

对于这两种情况该怎么解释呢?
代码如下:

public class Main

{

public static void main(String[] args)throws Exception

{

try {

ThreadB b = new ThreadB() ;

ThreadA a = new ThreadA(b) ;

a.start();

b.start();

b.join(2000) ;//似乎问题的关键就是这一行, 但是我无法解释为什么

System.out.println("main end");

Thread.sleep(1);

}

catch (InterruptedException e)

{

e.printStackTrace();

}

}

}

class ThreadA extends Thread

{

private ThreadB b ;

public ThreadA(ThreadB b) {

this.b = b;

}

@Override

public void run() {

try {

synchronized (b)

{

System.out.println("threadA sleep start ....");

this.sleep(5000) ;

System.out.println("threadA sleep end....");

}

}

catch (InterruptedException e)

{

e.printStackTrace() ;

}

}

}

class ThreadB extends Thread

{

@Override

public synchronized void run() {

try {

System.out.println("threadB sleep start....");

this.sleep(5000);

System.out.println("threadB sleep end....");

}

catch (InterruptedException e)

{

e.printStackTrace() ;

}

}

}

回答:

关键在于

 synchronized (b)

{

System.out.println("threadA sleep start ....");

this.sleep(5000) ;

System.out.println("threadA sleep end....");

}

b.join(2000);

这两块代码是互斥的,有一处拿到了锁,另一处就会阻塞在那里。原因是当synchronized的参数是一个对象,那么该对象的synchronized方法都会被阻塞,而join恰恰是synchronized的

这两块代码谁先执行,结合楼主自己说的join的等待时间,会产生各种结果

回答:

我好像明白了.... 问题的关键就在于等待的时间, A会等该5000 , B会等待5000, main只能等2000 , 因此在调用start方法之后, 如果A和B线程只是进入了就绪队列, 并未上CPU执行, 那么main的join方法就会执行, 开始等待, 因此在A或B执行等待2000之后, 就会退出等待, 打印输出.

回答:

好像是没有在run里面使用synchronized关键字。。要用也是用在Thread对象上

以上是 java多线程join的使用? 的全部内容, 来源链接: utcz.com/p/178078.html

回到顶部