线程的生命周期
- 新建(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() 办法来完结该线程,该办法容易导致死锁,通常不举荐应用。