位置: IT常识 - 正文

java多线程之线程的六种状态(java多线程线程数控制在多少)

编辑:rootadmin
java多线程之线程的六种状态 线程的六种状态(1) NEW(初始状态)(2) TERMINATED(终止状态 / 死亡状态)(3) RUNNABLE(运行时状态)(4) TIMED_WAITING(超时等待状态)(5) WAITING(等待状态)(6) BLOCK(阻塞状态)sleep和wait的区别:

推荐整理分享java多线程之线程的六种状态(java多线程线程数控制在多少),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:java多线程之线程组与线程池,java多线程线程池使用,java多线程线程池面试题,java多线程线程池异步返回结果,java多线程线程池参数,java多线程线程池异步返回结果,java多线程之线程组与线程池,java多线程之线程组与线程池,内容如对您有帮助,希望把文章链接给更多的朋友!

操作系统里的线程自身是有一个状态的,但是java Thread 是对系统线程的封装,把这里的状态又进一步细化了~~

状态说明NEW线程还没有创建,但是线程对象已经创建出来了TERMINATED线程结束了,但是线程对象还存在RUNNABLE就绪状态,可以细分为两个状态TIMED_WAITING指超时等待状态BLOCK等待状态WAITING表示阻塞时出现的状态

下面将通过代码运行结果来带大家细致了解线程运行的状态.

(1) NEW(初始状态) public static void main(String[] args) { Thread t = new Thread(()->{ System.out.println("t 线程"); }); //获取线程的状态 System.out.println("当前线程是 " +t.getState() + "状态"); //调用start(),创建这个线程 t.start(); }

NEW状态指的是 : 线程在刚刚被new出来的时候,还没有调用start()的状态.

此时可以称这个状态为: (1) 初始状态 (2) 创建状态

运行结果:

(2) TERMINATED(终止状态 / 死亡状态)public static void main(String[] args) { Thread t = new Thread(()->{ System.out.println("t 线程"); }); //调用start(),创建这个线程 t.start(); try { //由于计算机的执行速度是很快的,所以1000ms足够t线程执行完 Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } //获取线程的状态 System.out.println("当前线程是 " +t.getState() + "状态"); t.start(); }

如果一个线程的 run() 方法执行结束 该线程就会死亡,对于已经死亡的线程,无法再使用 start() 方法令其进入就绪.

运行结果:

(3) RUNNABLE(运行时状态)

运行时状态可以细分为两个状态:(1) 正在运行状态RUNNING (2) 就绪状态READY

我们可以这么理解 :

(1) 例如我女朋友下班了,我正在带我女朋友去吃饭,此时就是正在运行状态. (2)因为我提前下班了,但是我女朋友还没有下班,所以此时我在女朋友公司门口等她,只要她下班我随时可以带她吃饭去,此时我就是就绪状态.

通过代码实现(1) :

public static void main(String[] args) { Thread t = new Thread(()->{ while(true){ //什么都不打印,防止把下面的打印信息冲走 } }); //调用start(),创建这个线程 t.start(); //运行线程时判断此时的状态 System.out.println("当先线程是 "+t.getState()+"状态"); }

由于此时的 t 线程一直在执行死循环,所以 t 线程的状态是正在运行的~~

运行结果:

(4) TIMED_WAITING(超时等待状态)

可以理解为,具有指定等待时间的,正在等待(阻塞)线程的线程状态,由于调用具有指定等待时间的以下方法之一,线程处于定时等待状态.

具有指定等待时间的方法:

(1) Thread.sleep(参数)指定时间,单位为ms 该方法会让当前线程暂停一段时间,其他线程有机会获得 CPU 时间片。 (2) t.join(参数) 调用 t.join 的线程需要等待线程 t 执行指定时间后,才可以运行,等待的过程中是处于阻塞状态的. (3) wait(参数) :wait 方法提供一个带有 timeout 参数的版本, 来指定等待时间.超过这个时间之后无需其他线程调用该对象的 notify() 或 notifyAll() 方法唤醒该线程,该线程自己就会唤醒.

java多线程之线程的六种状态(java多线程线程数控制在多少)

代码实现(1)

public static void main(String[] args) { Thread t = new Thread(()->{ try { //睡眠1000ms Thread.sleep(1000); System.out.println("hello t"); } catch (InterruptedException e) { e.printStackTrace(); } }); //调用start(),创建这个线程 t.start(); try { //等待1000ms,此时t线程就创建结束,系统自动执行run方法里面的逻辑 Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } //运行线程时判断此时的状态 System.out.println("当先线程是 "+t.getState()+"状态"); }

运行结果:

代码实现(2)

public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(()->{ while (true){ try { //每500ms打印一次 Thread.sleep(500); System.out.println("t1"); } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread t2 = new Thread(()->{ try { //等待t1线程执行完1000ms //t2线程再开始执行 t1.join(1000); System.out.println("t2"); } catch (InterruptedException e) { e.printStackTrace(); } }); //创建t1线程 t1.start(); //创建t2线程 t2.start(); //等待500ms此时两个线程都创建完毕 Thread.sleep(500); System.out.println("当先线程是 "+t2.getState()+"状态"); }

运行结果:

代码实现(3)

public class ThreadDemo8 {//自己指定的锁对象 static Object object = new Object(); public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(()->{ //两个锁对象相同 synchronized (object){ for (int i = 0; i < 10; i++) { if(i == 5) { try { object.wait(1000); //虽然过了1000ms,但是还是需要等待t2线程中锁里面的程序执行完 // 才可以继续执行锁.(这里是指,仅有两个锁,且锁对象相等的情况) } catch (InterruptedException e) { e.printStackTrace(); } } System.out.println(i); } } }); Thread t2 = new Thread(()->{ //两个锁对象相同 synchronized (object){ for (int i = 0; i <10 ; i++) { try { System.out.println("t2"); Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } } } }); //t1线程先创建 t1.start(); //等待100ms是防止t2先抢到锁 Thread.sleep(100); //创建t2线程 t2.start(); //查看当前线程的状态 System.out.println("当先线程是 "+t1.getState()+"状态"); }}

运行结果:

(5) WAITING(等待状态)

处于这种状态的线程不会被CPU分配执行时间,他们要等待的显示被唤醒,否则会处于无限期的等待状态

具有阻塞的方法:

(1)使用 Thread.join() 方法。该方法会让当前线程等待另一个线程终止 (2) 使用 Object.wait() 方法。该方法会让当前线程等待,直到其他线程调用该对象的 notify() 或 notifyAll() 方法唤醒该线程。

我们这里只演示第一种就好~

public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(()->{ while (true){ } }); Thread t2 = new Thread(()->{ try { t1.join(); } catch (InterruptedException e) { e.printStackTrace(); } },"猪猪侠"); //创建这t1线程 t1.start(); //等待200ms让t1线程优先创建好 Thread.sleep(200); //创建这t2线程 t2.start(); //等待200ms让t2线程优先创建好 Thread.sleep(200); System.out.println("当先线程 "+t2.getName()+"的状态是"+t2.getState()+"状态"); }

运行结果是:

(6) BLOCK(阻塞状态)

阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃cpu的使用权,暂停或停止运行,直到线程进入就绪状态,才有机会获得cpu的青睐从而转入运行状态。

我们可以通俗点理解为~ 等待锁的状态.

例如: t1 和 t2 需要的锁对象相同,如果此时 t1 拿到了锁,当 t2 执行到进入锁的代码的时候, t2 就需要等 t1 释放锁之后才可以拿到这把锁.

我们通过代码演示:

public class ThreadDemo8 { static Object object = new Object(); public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(()->{ //两个锁对象相同 synchronized (object){ while (true){ } } }); Thread t2 = new Thread(()->{ //两个锁对象相同 //由于先执行的t1所以需要等t1释放锁才可以执行t2 //此时t2处于阻塞状态 synchronized (object){ System.out.println("t2"); } },"猪猪侠"); //创建这t1线程 t1.start(); //等待200ms让t1线程优先创建好 Thread.sleep(200); //创建这t2线程 t2.start(); //等待200ms让t2线程优先创建好 Thread.sleep(200); //查看t2线程的状态 System.out.println("当先线程 "+t2.getName()+"的状态是"+t2.getState()+"状态"); }}

运行结果:

关于线程状态的关系图:

sleep和wait的区别:

sleep()和wait()方法有什么区别:  sleep()睡眠时,保持对象锁,仍然占有该锁;  而wait()睡眠时,释放对象锁。  但是wait()和sleep()都可以通过interrupt()方法打断线程的暂停状态,从而使线程立刻抛出InterruptedException(但不建议使用该方法)。

本文链接地址:https://www.jiuchutong.com/zhishi/297803.html 转载请保留说明!

上一篇:讯飞AIUI智能机器人5-----让器理解你(语音技术综合应用)(讯飞智能x2)

下一篇:博客系统(页面设计)(博客界面模板)

  • 补做前几年税审对报税税务评级有什么影响?
  • 应付账款支付时需要付款申请单吗
  • 农产品增值税加计扣除可以补申报吗
  • 工业企业取得土地收益
  • 外资研发中心认定标准
  • 附加税减半征收的条件
  • 汇算清缴结束后,税务机关发现企业应当取得
  • 个人与公司交的税怎么算
  • 公司代个人收承兑汇票
  • 税金及附加包括个人所得税吗
  • 交防伪税控服务费怎么交
  • 建安企业增值税预缴
  • 本行给企业发放贷款收回利息分录?
  • 一次还本付息债券到期收益率
  • 税收分类编码如何添加
  • 应交增值税已交税金的账务处理
  • 混合销售行为如何缴纳消费税
  • 发票金额是价税价格吗
  • 物业公司怎么开展业务
  • 关于不动产进项税额分期抵扣的新政策,以下不属于
  • 增值税纳税申报表电子版在哪下载
  • 预付账款后期如何冲销
  • 固定资产采用历史成本计价
  • 已备案购销合同
  • 原材料对外投资进项税额可以抵扣吗
  • 公司购买自用房产税如何征收
  • 穿越火线改名卡买完了怎么用
  • apple mac 系统
  • 内含报酬率概念
  • win服务器安装
  • 王者荣耀中孙尚香怎么玩
  • 劳务报酬必须要和工资申报吗
  • ajax调用php函数
  • 恶搞代码vbs教程
  • 营改增建筑企业增值税
  • 归属性质
  • layuiadmin动态菜单
  • elementui ts
  • laravel注入
  • Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
  • tailf命令 查看100行
  • 金税盘白盘怎么分发发票
  • 电子税务局没有开票业务
  • 律师事务所主要业务范围介绍
  • pycharm操作界面
  • php.ini上传限制
  • 分公司从总公司进货不开票违法吗
  • 增值税税款抵扣
  • sqlserver游标实例
  • 小规模公司购买水泥怎么入账
  • 赠品视同销售会计分录如何编制?
  • 职工福利费如何入账
  • 从基本存款账户划款3万元 向开户银行转帐
  • 购进货物的运费税率是从主吗
  • 生育津贴领取条件及流程
  • 医院床单被套尺寸
  • redhat系统安装gvim
  • xp系统怎么强制结束进程
  • os x10.10.5 beta下载 mac os x10.10.5beta官方下载地址
  • win10任务栏跳来跳去
  • 在Linux系统中安装虚拟window
  • 手机屏幕尺寸测量工具
  • 画布canvas的基本步骤
  • 深入理解javascript特性.pdf
  • linux c程序开发
  • js去除hover样式
  • js html css
  • 批处理 leq
  • python 如何
  • jQuery Ajax传值到Servlet出现乱码问题的解决方法
  • javascript语言基础
  • webgl fbo
  • JavaScript 中的事件教程
  • django的url
  • jQuery soColorPacker 网页拾色器
  • Python+Pika+RabbitMQ环境部署及实现工作队列的实例教程
  • 建筑企业个人所得税管理办法
  • 税法税收保全的适用范围
  • 江苏医保给家人用怎么操作
  • 房屋契税交错了能退吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设