java多线程的协作

时间:2021-06-25 23:06:30

java多线程之间相互协作,主要有join,  yield,  interupt(),  sleep,  wait,  notify,  notifyAll;

join: 在一个线程A的代码里面调用另一个线程B的join方法(B.join()或者B.join(long times)),意味着A要等B执行完(或者等待times时间)才继续向下执行。如果等待times时间,不管B执行不执行完备都继续向下执行;如果是join, join的底层是join(0),意味着一直等待下去,join的实现是对wait()的封装。当A调用B.join()时候,就是A去获得B的对象锁,拿到锁后,调用wait,直到B唤醒A继续执行。

http://java.chinaitlab.com/base/828720_2.html

yield:  为了防止某个线程独占资源,调用yield,对线程调度器发出一种建议,声明“我已经完成生命周期中最重要的部分啦,此刻是切换给其他同优先级的任务执行一段时间的大好时机”,但是只是建议,如果没有其他同优先级的,则该线程继续占用CPU.

interupt():  中断是一种协作机制, 当在A中调用B.interupt(),不是一定要中断B进程,而是请求B在方便的时候终止正在做的事情(预示着线程结束吗?)

http://www.ibm.com/developerworks/cn/java/j-jtp05236.html