java 多线程状态_JAVA多线程--线程状态

线程状态图(来源于网络)

c69c0e53f42cc8be66aa2796b26126af.png

线程共包括以下5种状态。

1. 新建状态(New): 线程对象被创建后,就进入了新建状态。例如,Thread thread = new Thread()。

2. 就绪状态(Runnable): 也被称为“可执行状态”。线程对象被创建后,其它线程调用了该对象的start()方法,从而来启动该线程;或者线程获取锁、sleep结束、join结束从而结束Blocked状态。处于就绪状态的线程,随时可以获得CPU时间片执行。

3. 运行状态(Running) : 线程获取CPU权限进行执行。需要注意的是,线程只能从就绪状态进入到运行状态。

4. 阻塞状态(Blocked) : 阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的情况分三种:

(01) 等待阻塞 -- 通过调用线程的wait()方法,让线程等待某工作的完成。

(02) 同步阻塞 -- 线程在获取synchronized同步锁失败(因为锁被其它线程所占用),它会进入同步阻塞状态。

(03) 其他阻塞 -- 通过调用线程的sleep()或join()或发出了I/O请求时,线程会进入到阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

5. 死亡状态(Dead)    : 线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

那jstack命令看到的堆栈信息中RUNNABLE/BLOCKED/TIMED_WAITING/WAITING状态又是怎么回事呢?(注:jstack是将在线程处于safepoint时输出线程堆栈信息,所以同一个堆栈文件打印的线程信息是不同步的,不是同一时间点的信息。)

JVM中线程状态(图片来源网络):

ff09596aa85180438d97b94547a0ab3a.png

RUNNABLE 线程运行中或I/O等待

BLOCKED线程在等待monitor锁(synchronized关键字),等待ReentrantLock则不会,sleep会持有锁,wait不会。

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

public classBlockedTest {public static voidmain(String[] args) {final Object lock = newObject();newThread() {public voidrun() {synchronized(lock) {try{

Thread.sleep(1000 * 1000);

}catch(InterruptedException e) {

}

}

}

}.start();try{

Thread.sleep(100);

}catch(InterruptedException e) {

}synchronized(lock) {try{

Thread.sleep(30 * 1000);

}catch(InterruptedException e) {

}

}

}

}

View Code

主线程BLOCKED状态

1139fcd1dcca2d9b95599c516ff6889a.png

锁持有线程处于TIME_WAITING状态,等待sleep结束。

6d20afecaf8cd4543b23a941f33fd078.png

TIMED_WAITING线程在等待唤醒,但设置了时限。用Lock.tryLock(timeout, timeUnit),这种方式也会看到TIMED_WAITING状态

public static voidtimedWaiting() {final Object lock = newObject();synchronized(lock) {try{

lock.wait(10 * 1000);

}catch(InterruptedException e) {

}

}

}

WAITING线程在无限等待唤醒,无超时的等待,必须等待lock.notify()或lock.notifyAll()或接收到interrupt信号才能退出等待状态。同理,ReentrantLock.lock()的无参方法调用,也会使线程状态变成WAITING。

public static void waiting() {

final Object lock = new Object();

synchronized (lock) {

try {

lock.wait();

} catch (InterruptedException e) {

}

}

}

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

public classReentrantLockTest {public static voidmain(String[] args) {final ReentrantLock lock = newReentrantLock();newThread() {public voidrun() {

lock.lock();try{

Thread.sleep(1000 * 1000);

}catch(InterruptedException e) {

}

lock.unlock();

}

}.start();try{

Thread.sleep(100);

}catch(InterruptedException e) {

}

lock.lock();

}

}

ReentrantLock

7252f29c7d0662fcf4f4e319e3fbc8f6.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值