您的位置:首页 > 编程语言

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

2017-08-18 11:40 302 查看
在很多情况下,一个线程的输出可能非常依赖于另外一个或者多个线程的数据。在这种情况下,这个线程就需要等待依赖线程执行完毕,才能继续执行。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{
@Override
public 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。
他表示会给其他重要的线程更多的执行机会
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐