标签:
1. 首先是线程的sleep和yeld
sleep会阻塞当前线程,使所有优先级的线程都可以获取执行机会,但并不释放当前线程已经获得的锁
yeld,线程回到可执行状态,同优先级的线程才可获取执行机会,不释锁
还有两个经常放一块对比:
join(1000)并不能真实表现当前线程等待1000毫秒,解释下,join(1000)后,
线程0还没有获取线程1对象锁,如果有其它线程3获得线程1对象锁,线程0就阻塞在synchronized
2. 线程状态
public enum State { //线程刚创建 NEW, //start,在JVM中正在运行的线程 RUNNABLE, //线程处于阻塞状态,等待监视锁,可以重新进行同步代码块中执行 BLOCKED, //调用join() wait()方法
WAITING,
//调用sleep(时间) join(时间) wait(时间)方法
TIMED_WAITING,
//线程执行完毕,已经退出
TERMINATED;
}
参考文章:
1. java 线程的几种状态
标签:
原文地址:http://www.cnblogs.com/yhzh/p/5888878.html