线程的生命周期
- 新建(New)
- 就绪(Runnable)
- 运行(Running)
- 阻塞(Blocked)
- 死亡(Dead)
新建和就绪状态
新建
- 当程序应用new关键字创立了一个线程后,该线程就处于新建状态,此时它和其余的Java对象一样,仅仅由Java虚拟机为其分配内存,并初始化其成员变量的值。此时的线程对象没有体现出任何线程的动静特色,程序不会执行线程的线程执行体。
就绪
- 当线程对象调用了start()办法之后,该线程处于就绪状态,Java虚构机会为其创立办法调用栈和程序计数器,处于这个状态中的线程并没有开始运行,只是示意该线程能够运行。至于该线程何时开始运行,取决于JVM里线程调度器的调度。
特地留神
- 启动线程应用start()办法,而不是run()办法。永远不要调用线程对象的run()办法。
- 调用start()办法来启动线程,零碎会把run()办法当成线程执行体来解决。
- 但如果间接调用线程对象的run()办法,则run()办法立刻就会被执行,而是在run()办法返回之前其余线程无奈并发执行。也就是说,零碎把线程对象当成一个一般对象,而run()办法也是一个一般办法,而不是线程执行体。
运行和阻塞和就绪状态
运行
- 如果处于就绪状态的线程取得了CPU,开始执行run()办法的线程执行体,则该线程处于运行状态。
阻塞
- 线程调用sleep()办法被动放弃所占用的处理器资源,线程进入阻塞状态。
- 线程调用了一个阻塞式IO办法,在该办法返回前,该线程被阻塞。
- 线程试图取得一个同步监听器,该同步监听器正被其余线程所持有,即,期待同步锁,该线程被阻塞。
- 线程在期待某个告诉(notify)
- 程序调用了线程的suspend()办法将该线程挂起。但这个办法容易导致死锁,所以应该尽量避免应用该办法。
就绪
- sleep()工夫到
- IO办法返回
- 取得同步锁
- 收到告诉
- resume()
线程死亡
- 线程run()或者call()办法执行实现,线程失常完结。
- 线程抛出一个未捕捉的Exception或Error。
- 线程间接调用stop()办法来完结该线程,该办法容易导致死锁,通常不举荐应用。