JAVA内存模型与线程(二)

JAVA线程调度

  • 协同式线程调度

    线程的执行时间由线程本身来控制,线程把自己的工作执行完了之后,要主动通知系统切换到另外一个线程上。优点:实现简单。缺点:执行时间不可控制。

  • 抢占式线程调度

    每个线程由系统分配执行时间,线程的切换不由线程本身决定。Java使用的就是这种线程调度方式。在这种实现线程调度的方式下,线程的执行时间是系统可控的,不会有一个线程导致整个进程阻塞的问题。

    Java提供10个级别的线程优先级设置,来让某个线程可以分配多一点的执行时间,不过Java线程是被映射到系统的原生线程上实现的,所以线程调度最终还是由操作系统决定

状态转移

  • 新建(New):创建尚未启动的线程处于这种状态。

  • **运行(Runable):**包括操作系统线程状态中的Running和Ready,处于此状态的线程可能正在运行,也可能等待着CPU为它分配执行时间。

  • **无限期等待(Waiting):**处于这种状态的线程不会被分配CPU执行时间,它们要等待其他线程显示地唤醒。以下方法会让线程陷入无限期的等待状态:

    ​ 没有设置Timeout参数的Object.wait()方法。

​ 没有设置Timeout参数的Thread.join()方法。

​ LockSupport.park()方法。

  • **限期等待(Timed Waiting):**处于这种状态的线程也不会被分配CPU执行时间,不过无须等待被其他线程显示地唤醒,在一定时间后由系统自动唤醒。以下方法会让线程陷入限期的等待状态:

    ​ Thread.sleep()方法。

​ 设置了Timeout参数的Object.wait()方法。

​ 设置了Timeout参数的Thread.join()方法。

​ LockSupport.parkNanos()方法。

​ LockSupport.parkUntil()方法。

  • **阻塞(Blocked):线程被阻塞了,“阻塞状态”与“等待状态”的区别是:“阻塞状态”在等待获取一个排它锁,这个事件将在另外一个线程放弃这个锁的时候发生;“等待状态”则是在等待一段时间,或者唤醒动作的发生。**在程序进入等待进入同步块区域的时候,线程将进入这种状态。

  • **结束(Terminated):**已终止线程的线程状态,线程已经结束执行。
    在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值