《并发编程》--5.线程等待结束(join)和线程谦让(yield)

来源:互联网 发布:soundhound mac 编辑:程序博客网 时间:2024/05/21 12:22

在很多情况下,一个线程的输出可能非常依赖于另外一个或者多个线程的数据。在这种情况下,这个线程就需要等待依赖线程执行完毕,才能继续执行。jdk就给我们提供了join()这个方法。

public final void join() throws InterruptedException;
public final synchronized void join(long millis) throws InterruptedException

第一个方法表示无限等待,他会一直阻塞当前线程,直至目标线程执行完毕,当前线程才能继续执行

第二个方法是设置最大的等待时间,如果超过这个时间将不会继续等待

以后提供一个demo方便理解

public class join {public volatile static int i = 0;public static class addThread extends Thread{@Overridepublic void run(){for(int i = 0;i<999999999;i++);}}public static void main(String[] args) throws InterruptedException{addThread at = new addThread();at.start();at.join();//若不使用join,主函数会数据一个很小的数字,甚至是0          //使用后表示愿意等待addThread执行完毕System.out.println(i);}}

其实join的核心代码就是

while(isAived){wait(0);}
当其他线程执行完毕,或者超过等待时间将会执行notity方法。


public static native void yield();
yield是一个静态的方法,如果一个线程不是那么的重要,或者优先级特别的低,并且希望他不要占用太多的cpu,就可以在适当的地方调用thread.yield。

他表示会给其他重要的线程更多的执行机会

原创粉丝点击