Threads
Definition:
Within a program, a Thread is a separate execution path.
It is a lightweight process that the operating system can schedule and run
concurrently with other threads.
The operating system creates and manages threads, and they share the same
memory and resources as the program that created them.
This enables multiple threads to collaborate and work efficiently within a
single program.
A thread is a single sequence stream within a process.
Threads are also called lightweight processes as they possess some of the
properties of processes.
Threads allows a program to operate more efficiently by doing multiple
things at the same time.
Threads can be used to perform complicated tasks in the background without
interrupting the main program.
Creating a Thread:
There are two ways to create a thread.
It can be created by extending the Thread class and overriding its run() method:
Extend Syntax:
public class Main extends Thread {
public void run() {
System.out.println("This code is running in a thread");
}
}
1
Another way to create a thread is to implement the Runnable interface:
Implement Syntax:
public class Main implements Runnable {
public void run() {
System.out.println("This code is running in a thread");
}
}
Life cycle of a Thread (Thread States):
In Java, a thread always exists in any one of the following states.
These states are:
1. New
2. Active
3. Blocked / Waiting
4. Timed Waiting
5. Terminated
The following diagram shows the different states involved in the life cycle
of a thread.
2
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.
3
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.
EXAMPLE:
Implementing runnable interface by extending Thread class :
ThreadExample1.java
public class ThreadExample1 extends Thread {
// run() method to perform action for thread.
public void run()
{
int a= 10;
int b=12;
int result = a+b;
System.out.println("Thread started running..");
System.out.println("Sum of two numbers is: "+ result);
}
public static void main( String args[] )
{
// Creating instance of the class extend Thread class
ThreadExample1 t1 = new ThreadExample1();
//calling start method to execute the run() method of the Thread class
t1.start();
}
}
4
Output:
Thread Methods:
Following is the list of important methods available in the Thread class.
Method & Description
public void start()
Starts the thread in a separate path of execution, then invokes the run()
method on this Thread object.
public void run()
If this Thread object was instantiated using a separate Runnable target,
the run() method is invoked on that Runnable object.
public final void setName(String name)
Changes the name of the Thread object. There is also a getName()
method for retrieving the name.
public final void setPriority(int priority)
Sets the priority of this Thread object. The possible values are between 1
and 10.
5
public final void setDaemon(boolean on)
A parameter of true denotes this Thread as a daemon thread.
public final void join(long millisec)
The current thread invokes this method on a second thread, causing the
current thread to block until the second thread terminates or the specified
number of milliseconds passes.
public void interrupt()
Interrupts this thread, causing it to continue execution if it was blocked
for any reason.
public final boolean isAlive()
Returns true if the thread is alive, which is any time after the thread has
been started but before it runs to completion.
The following methods in the Thread class are static.
Method & Description
public static void yield()
Causes the currently running thread to yield to any other threads of the
same priority that are waiting to be scheduled.
public static void sleep(long millisec)
Causes the currently running thread to block for at least the specified
number of milliseconds.
public static boolean holdsLock(Object x)
6
Returns true if the current thread holds the lock on the given Object.
public static Thread currentThread()
Returns a reference to the currently running thread, which is the thread
that invokes this method.
public static void dumpStack()
Prints the stack trace for the currently running thread, which is useful
when debugging a multithreaded application.
Multitasking in Java:
Multitasking is the process that lets users perform multiples tasks at the
same time. There are two ways to enable multitasking in Java:
1. Process-based multitasking:
The processes in this type of multitasking are heavy and a lot of time is
consumed. This is because the program takes a long time to switch between
different processes.
2. Thread-based multi tasking:
Threads are light-weight compared to process-based multi tasking, and the
time taken to switch between them is shorter.
Multi-Threading in Java:
7
As I briefly explained above, multithreading in Java refers to the execution of
several threads at the same time.
Multithreading is useful because threads are independent – and in
multithreading we can perform the execution of several threads at the same
time without blocking the user.
It also helps us save time as we can perform several operation at the same
time.
A good real time example of multi threading in Java is word processing.
This program checks the spelling of what we're typing while we write a
document. In this case each task will be provided by a different thread.
Use cases of multi-threading in Java
Now that you know how multi-threading saves time by allowing you to perform
multiple operation together, let's learn about some practical uses cases of multi-
threading:
1. Word processing, which we discussed above.
2. Gaming.
3. Improving the responsiveness of a server.
4. Using thread synchronization functions to provide enhanced processes to process
communication.