Course
Thread Life Cycle
Java Tutorial
This Java tutorial is tailored for newcomers, offering a journey from basic principles to complex Java programming techniques. Completing this tutorial equips you with a solid understanding of Java, preparing you for advanced learning. You'll emerge ready to tackle the challenges of becoming a top-tier software engineer, with the skills to innovate and excel in the vast world of software development.
Thread Life Cycle
Life Cycle of a Thread in Java
The life cycle of a thread in Java refers to the various states of a thread goes through. For example, a thread is born, started, runs, and then dies. Thread class defines the life cycle and various states of a thread.
Flow Chart of Java Thread Life Cycle
The following diagram shows the complete life cycle of a thread.
States of a Thread Life Cycle in Java
Following are the stages of the life cycle
- New − A new thread begins its life cycle in the new state. It remains in this state until the program starts the thread. It is also referred to as a born thread.
- Runnable − After a newly born thread is started, the thread becomes runnable. A thread in this state is considered to be executing its task.
- Waiting − Sometimes, a thread transitions to the waiting state while the thread waits for another thread to perform a task. A thread transitions back to the runnable state only when another thread signals the waiting thread to continue executing.
- Timed Waiting − A runnable thread can enter the timed waiting state for a specified interval of time. A thread in this state transitions back to the runnable state when that time interval expires or when the event it is waiting for occurs.
- Terminated (Dead) − A runnable thread enters the terminated state when it completes its task or otherwise terminates.
Java Example for Demonstrating Thread States
In this example, we're creating two threads by extending the Thread class. We're printing each state of the thread. When a thread object is created, its state is NEW; when start() method is called, state is START; when run() method is called, state is RUNNING; When a thread finished the processing the run() method, it went to DEAD state.
package com.tutorialspoint;class ThreadDemo extends Thread { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); } public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } }}public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
Output
Thread: Thread-1, State: NewThread: Thread-2, State: NewThread: Thread-1, State: StartThread: Thread-2, State: StartThread: Thread-1, State: RunningThread: Thread-2, State: RunningThread: Thread-2, 4Thread: Thread-2, 3Thread: Thread-2, 2Thread: Thread-2, 1Thread: Thread-2, State: DeadThread: Thread-1, 4Thread: Thread-1, 3Thread: Thread-1, 2Thread: Thread-1, 1Thread: Thread-1, State: Dead
More Examples on Thread Life Cycle & States
Example 1
In this example,we're using sleep() method to introduce some delay in processing and to show case the parallel processing using threads. We're creating two threads by extending the Thread class. We're printing each state of the thread. When a thread object is created, its state is NEW; when start() method is called, state is START; when run() method is called, state is RUNNING; in case sleep() is called, then thread goes to WAITING state; When a thread finished the processing the run() method, it went to DEAD state.
package com.tutorialspoint;class ThreadDemo extends Thread { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); try { for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); // Let the thread sleep for a while. System.out.println("Thread: " + threadName + ", " + "State: Waiting"); Thread.sleep(50); } } catch (InterruptedException e) { System.out.println("Thread " + threadName + " interrupted."); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); }
public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } }}public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
Output
Thread: Thread-1, State: NewThread: Thread-2, State: NewThread: Thread-1, State: StartThread: Thread-2, State: StartThread: Thread-1, State: RunningThread: Thread-1, 4Thread: Thread-1, State: WaitingThread: Thread-2, State: RunningThread: Thread-2, 4Thread: Thread-2, State: WaitingThread: Thread-1, 3Thread: Thread-2, 3Thread: Thread-2, State: WaitingThread: Thread-1, State: WaitingThread: Thread-2, 2Thread: Thread-1, 2Thread: Thread-1, State: WaitingThread: Thread-2, State: WaitingThread: Thread-2, 1Thread: Thread-2, State: WaitingThread: Thread-1, 1Thread: Thread-1, State: WaitingThread: Thread-2, State: DeadThread: Thread-1, State: Dead
Example 2
In this example, we're creating two threads by implementing the Runnable class. We're printing each state of the thread. When a thread object is created, its state is NEW; when start() method is called, state is START; when run() method is called, state is RUNNING; in case sleep() is called, then thread goes to WAITING state; When a thread finished the processing the run() method, it went to DEAD state.
package com.tutorialspoint;class ThreadDemo implements Runnable { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); try { for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); // Let the thread sleep for a while. System.out.println("Thread: " + threadName + ", " + "State: Waiting"); Thread.sleep(50); } } catch (InterruptedException e) { System.out.println("Thread " + threadName + " interrupted."); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); }
public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } }}public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
Output
Thread: Thread-1, State: NewThread: Thread-2, State: NewThread: Thread-1, State: StartThread: Thread-2, State: StartThread: Thread-1, State: RunningThread: Thread-1, 4Thread: Thread-1, State: WaitingThread: Thread-2, State: RunningThread: Thread-2, 4Thread: Thread-2, State: WaitingThread: Thread-1, 3Thread: Thread-2, 3Thread: Thread-2, State: WaitingThread: Thread-1, State: WaitingThread: Thread-2, 2Thread: Thread-1, 2Thread: Thread-1, State: WaitingThread: Thread-2, State: WaitingThread: Thread-2, 1Thread: Thread-2, State: WaitingThread: Thread-1, 1Thread: Thread-1, State: WaitingThread: Thread-2, State: DeadThread: Thread-1, State: Dead