多线程执行过程(生命周期)

本文详细介绍了Java线程的五个状态:新建、就绪、运行、阻塞和死亡。从新建状态到通过start()进入就绪状态,再到获取CPU执行权进入运行状态。讨论了导致线程阻塞的各种情况,如sleep()、阻塞IO、同步监视器等。最后,线程可能因run()正常结束、异常或stop()方法而进入死亡状态。死亡线程无法再次启动。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 .
过程展示 在这里插入图片描述
2.
新建状态:当程序使用new关键字创建了一个线程之后,该线程就处于新建状态,此时仅由JVM为其分配内存,并初始化其成员变量的值
就绪状态:当线程对象调用了start()方法之后,该线程处于就绪状态。Java虚拟机会为其创建方法调用栈和程序计数器,等待调度运行
运行状态:如果处于就绪状态的线程获得了CPU,开始执行run()方法的线程执行体,则该线程处于运行状态
阻塞状态:当处于运行状态的线程失去所占用资源之后,便进入阻塞状态
死亡状态:线程在run()方法执行结束后进入死亡状态。此外,如果线程执行了interrupt()或stop()方法,那么它也会以异常退出的方式进入死亡状态。
3.
新建和就绪
程序使用new会新建一个线程,new出的对象跟普通对象一样,JVM会为其分配内存,初始化成员变量等,此时线程并没有运行,而是就是新建状态。

当线程对象调用start后,线程将进入就绪状态。JVM会为其创建函数调度栈和计数器,但此时线程依然没有运行,而是等待获取CPU执行片

下面的例子可以证明当线程对象调用start后,并不一定立即执行
4.
运行和阻塞状态
当就绪状态的线程获取了CPU执行片的之后,就进入运行状态,但是在执行过程中,可能会因为以下原因使线程进入阻塞状态,

CPU执行片已经用完,JVM切换到其他线程执行
线程调用sleep()
线程调用了阻塞IO方法,该方法返回之前,线程会一直阻塞
线程试图获取被其他线程持有的同步监视器
线程在等待某个通知
程序调用了线程的suspend()将线程挂起。(容易死锁,不推荐)
线程从运行进入阻塞状态之后,接着只能继续阻塞或者再次进入就绪状态,下面情况会使线程由阻塞状态重新进入就绪状态,

线程调用的slee()经过了指定时间
线程调用的阻塞IO方法返回
线程成功获取同步监视器
线程收到其他线程发出的通知
被挂起(suspend)的线程又被程序调用了resume方法
5.
线程死亡
线程结束后就处于死亡状态,线程会以如下三种方式结束,

run()或call()正常执行完成,线程正常结束
线程抛出一个未捕获的Exception或Error
直接调用线程的stop()方法结束线程,容易死锁
注意,子线程一旦启动,其地位和主线程是一样的,所以一旦主线程结束了,子线程不会受影响,不会跟着结束

线程对象的isAlive()方法在就绪,运行,阻塞时返回true,在新建,死亡时返回false

对已经死亡的线程调用start()是无效的,会抛出异常。 死亡的线程不可再次作为线程来执行。

对于新建的线程,调用两次start()方法也会抛出异常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值