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

在很多情况下,一个线程的输出可能非常依赖于另外一个或者多个线程的数据。在这种情况下,这个线程就需要等待依赖线程执行完毕,才能继续执行。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。

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值