Jvm笔记总结(十五):Java线程

Jvm笔记总结(十五):Java线程

PS : 本文乃学习整理参考而来 ,目录参考 [ Jvm系列目录 ]


Java线程调度

线程调度是指系统为线程分配处理器使用权的过程,主要调度方式有两种:分别是协同式调度抢占式调度

协同式线程调度线程的执行时间有线程本身控制,线程把自己的工作执行完了之后,要主动通知系统切换到另外一个线程上。很明显的缺点:线程执行时间不可控制,如果编写的程序有问题一直不告知系统进行线程切换那么程序会一直阻塞,导致一个进程坚持不让出CPU执行时间从而系统崩溃

抢占式线程调度线程执行时间有系统来分配线程的切换不由自身决定,而是系统可控的,不会出现一个线程导致进程阻塞Java使用的线程调度方式就是该调度方式虽然Java线程调度是系统自动完成的,但是还是可以建议系统给某些线程多分配一点执行时间,这项操作可以通过设置线程优先级来完成。两个同处于Ready状态的线程,优先级越高越容易被系统选择执行,但不是一定会先执行


状态转换

Java语言定义了5种线程状态,在任意时间点,一个线程只能有其中一种状态
1.新建(New)创建后尚未启动的线程

2.运行(Runable):Runable包括了操作系统线程状态中的RunningReady,也就是处于此状态的线程有可能正在执行也有可能正在等待这CPU为他分配执行时间

3.无限期等待(Waiting):处于这种状态的线程不会被分配CPU执行时间,他们要等待被其他线程显示唤醒。以下方法会让线程陷入无限期等待状态:
①.没有设置Timeout参数的Object.wait()方法。
②.没有设置Timeout参数的Thread.join()方法。
③.LockSupport.park()方法。

4.限期等待:(Timed Waiting):处于这种状态的线程不会被分配CPU执行时间不过无需被其他线程显示唤醒,在一定时间之后会由系统自动唤醒。以下方法会让线程进入限期等待状态:
①.Thread.sleep();
②.设置了Timeout参数的Object.wait()
③.设置了Timeout参数的Thread.join();
④.LockSupport.parkNanos();
⑤.LockSupport.parkUntil();

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

6.结束(Terminated):已终止线程的线程状态,线程已经结束执行。

如图:
这里写图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值