《并发编程》--5.线程等待结束(join)和线程谦让(yield)
2017-08-18 11:40
302 查看
在很多情况下,一个线程的输出可能非常依赖于另外一个或者多个线程的数据。在这种情况下,这个线程就需要等待依赖线程执行完毕,才能继续执行。jdk就给我们提供了join()这个方法。
public final void join() 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。
他表示会给其他重要的线程更多的执行机会
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。
他表示会给其他重要的线程更多的执行机会
相关文章推荐
- 关于线程中断interrupt()、谦让yield()、等待线程结束join()
- day12线程间的通信,等待唤醒机制,生产者消费者问题。新锁lock(): 守护线程,interrupt()停止线程用,join()yield()
- Thread.yield()方法表示交出主动权,join表示等待当前线程,可以指定秒数
- Java高并发--等待线程结束和谦让
- Java 并发编程中的 CountDownLatch 锁用于多个线程同时开始运行或主线程等待子线程结束
- 网络编程(35)—— 利用pthread_join函数等待线程结束并获取线程函数返回值
- 并发编程实战 1.5. 等待线程终止-join()方法
- Windows和Linux上分别怎样实现等待某个线程结束?---用WaitForSingleObject和pthread_join
- 黑马程序员:如何结束线程及线程中的其他方法介绍:interrupt()、join()、yield()等方法
- C# 多线程join的用法,等待多个子线程结束后再执行主线程
- Java Thread.join()详解--父线程等待子线程结束后再结束
- 主线程中使用join等待所有子线程执行结束
- No6.等待线程结束(join)和通知(notify)
- Java Thread.join()详解--父线程等待子线程结束后再结束
- C# 多线程的等待所有线程结束 用 ManualResetEvent 控制
- java 多线程(2) 线程的调度和优先级 / sleep() / interrupt() 打断join() / yield() / setPriority()
- Java线程中的join和yield
- 线程sleep,wait,join,yield方法的区别
- Java多线程-线程状态、sleep()、yield()、join()
- 多个子线程并发执行,主线程等待所有子线程都结束后再继续运行