《并发编程》--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。
他表示会给其他重要的线程更多的执行机会
阅读全文
0 0
- 《并发编程》--5.线程等待结束(join)和线程谦让(yield)
- Java高并发--等待线程结束和谦让
- No6.等待线程结束(join)和通知(notify)
- Java 并发编程:线程间的协作(wait/notify/sleep/yield/join) (r)
- Java 并发编程:线程间的协作(wait/notify/sleep/yield/join)(转)
- 线程等待 Join()方法
- java并发编程:主线程等待子线程结束 CountDownLatch
- Java 线程 | yield() 和 join()
- 《并发编程》--4.线程等待(wait)和线程通知(notity)
- 线程初步(五)---join,yield
- Java并发——线程间协作(wait、notify、sleep、yield、join)
- 并发编程--等待线程终止
- (55)join:等待线程终止
- Java并发编程番外篇(一)如何结束一个线程
- Java并发编程(二)线程同步和等待唤醒机制
- 线程Sleep、Yield、Join
- 线程:sleep()、wait()、yield()和join()方法
- 线程:sleep()、wait()、yield()和join()方法
- 攻击容器集群管理平台
- [leetcode]142. Linked List Cycle II@Java解题报告
- MFC学习笔记01-(_T()与L的区别)
- 软件测试过程中有哪些风险?
- 单链表的快排实现
- 《并发编程》--5.线程等待结束(join)和线程谦让(yield)
- String-引用计数的写时拷贝
- Python爬取表格及图片
- web.xml 配置-filter
- Highcharts如何设置背景颜色
- 页面表格数据下载到Excel的超实用方法
- android蓝牙
- mysql常见安全加固策略
- hdu2689树状数组