首页 > java多线程join的使用?

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() ;
        }

    }
}

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


关键在于

 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的等待时间,会产生各种结果


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

【热门文章】
【热门文章】