Open In App

Java ThreadGroup Class

Last Updated : 23 Apr, 2025
Comments
Improve
Suggest changes
Like Article
Like
Report

In Java, the ThreadGroup class creates a group of threads, and with the help of this, we can manage groups of threads as a unit. It is helpful when we need to control multiple threads as a single unit, such as suspending or resuming several related threads at once.

Features of the ThreadGroup Class:

  • The thread group forms a tree in which every thread group except the initial thread group has a parent.
  • A thread is allowed to access information about its thread group but not to access information about its thread group’s parent thread group or any other thread group.

Declaration of ThreadGroup Class

The Declaration of the ThreadGroup Class is listed below:

public class ThreadGroup extends Object implements Thread.UncaughtExceptionHandler

Constructors in ThreadGroup

This class consists of two constructors with the help of which we can create objects of this class in different ways. The following are the constructors available in this class:

1. public ThreadGroup(String name): Constructs a new thread group. The parent of this new group is the thread group of the currently running thread.

Syntax:

public ThreadGroup(String name)

2. public ThreadGroup(ThreadGroup parent, String name): Creates a new thread group. The parent of this new group is the specified thread group.

Syntax:

public ThreadGroup(ThreadGroup parent, String name)

Java ThreadGroup Methods

Now, we are going to discuss about each method one by one in detail:

1. int activeCount(): This method returns the number of threads in the group plus any group for which this thread is parent.

Syntax:

public int activeCount()

  • Parameter: This method does not take any parameter
  • Return Type: This method returns an estimate of the number of active threads in this thread group and in any other thread group that has this thread group as an ancestor.

Example:

Java
// Java Program to demonstrates the 
// working of activeCount() method

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 1000; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
    }
}
public class Geeks
{
    public static void main(String arg[])
    {
        // creating the thread group
        ThreadGroup t = new ThreadGroup("parent thread group");

        NewThread t1 = new NewThread("one", t);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", t);
        System.out.println("Starting two");

        // checking the number of active thread
        System.out.println("number of active thread: "
                + t.activeCount());
    }
}

Output:

Output


2. int activeGroupCount(): This method returns an estimate of the number of active groups in this thread group.

Syntax:

public int activeGroupCount()

  • Parameter: This method does not take any parameter
  • Return Type: Returns the number of groups for which the invoking thread is parent.

Example:

Java
// Java program to demonstrates 
// the working of activeGroupCount() method

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 1000; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("gfg");

        ThreadGroup gfg_child = new ThreadGroup(g, "child");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");

        // checking the number of active thread
        System.out.println("number of active thread group: "
                + g.activeGroupCount());
    }
}

Output:

Output


3. void checkAccess(): Causes the security manager to verify that the invoking thread may access and/ or change the group on which checkAccess() is called.

Syntax:

final void checkAccess()

  • Parameter: This method does not take any parameter.
  • Return Type: This method does not return anything.

Note: This method is now depricated.


4. void destroy(): Destroys the thread group and any child groups on which it is called.

Syntax:

public void destroy()

  • Parameter: This method does not take any parameter
  • Return Type: This method does not return anything.

Note: This method is now depricated.


5. int enumerate(Thread group[]): The thread that comprise the invoking thread group are put into the group array.

Syntax:

public int enumerate(Thread group[]).

  • Parameter: This method takes a single parameter Thread group[], which is an aray of Thread objects.
  • Return Type: Return the number of threads put into the array.

Example:

Java
// Java Program to demonstrates 
// the working of enumerate() method.

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex) {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");

        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");

        // returns the number of threads put into the array
        Thread[] group = new Thread[g.activeCount()];
        int count = g.enumerate(group);
        for (int i = 0; i < count; i++)
        {
            System.out.println("Thread " + group[i].getName() + " found");
        }
    }
}

Output:

Output


6. int enumerate(Thread[] group, boolean recurse): The threads that comprise the invoking thread group are put into the group array. If all is true, then threads in all subgroups of the thread are also put into group.

Syntax:

public int enumerate(Thread[] list, boolean recurse)

  • Parameter: This method take two parameter.
    • Thread[] list: It is an array of thread objects where all the threads will stored
    • boolean recurse: If it’s true, then it includes threads from all subgroups and if false then only the threads in the current group is included.
  • Return Type: Return the number of threads placed into the array.

Example:

Java
// Java program to demonstrates the 
// working of enumerate(Thread[] group, boolean recurse)

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");

        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");

        // returns the number of threads put into the array
        Thread[] group = new Thread[g.activeCount()];
        int count = g.enumerate(group, true);
        for (int i = 0; i < count; i++)
        {
            System.out.println("Thread " + group[i].getName() + " found");
        }
    }
}

Output:

Output


7. int enumerate(ThreadGroup[] group): The subgroups of the evoking thread group are put into the group array.

Syntax:

public int enumerate(ThreadGroup[] group)

  • Parameter: This method takes an array to store the subgroups.
  • Return Type: Return the number of thread groups put into the array.

Example:

Java
// Java program to demonstrates the working 
// of enumerate(ThreadGroup[] group) method


import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");

        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");

        // returns the number of threads put into the array
        ThreadGroup[] group = new ThreadGroup[g.activeCount()];
        int count = g.enumerate(group);
        for (int i = 0; i < count; i++)
        {
            System.out.println("ThreadGroup " + group[i].getName() +
                    " found");
        }
    }
}

Output:

Output


8. int enumerate(ThreadGroup[] group, boolean all): The subgroups of the invoking thread group are put into the group array. If all is true, then all subgroups of the subgroups(and so on) are also put into group.

Syntax:

public int enumerate(ThreadGroup[] group, boolean all)

  • Parameter: This method takes two parameters
    • ThreadGroup: It is an array to store the subgroup
    • boolean all: If it’s true then it includes subgroups and if it is false then it includes only immediate subgroups
  • Return Type: Return the number of thread groups put into the array.

Example:

Java
// Java code to demonstrates the working
// of enumerate(ThreadGroup[] group, boolean all)

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");

        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");

        // returns the number of threads put into the array
        ThreadGroup[] group = new ThreadGroup[g.activeCount()];
        int count = g.enumerate(group, true);
        for (int i = 0; i < count; i++)
        {
            System.out.println("ThreadGroup " + group[i].getName() +
                    " found");
        }
    }
}

Output:

Output


9. int getMaxPriority(): Returns the maximum priority setting for the group.

Syntax:

final int getMaxPriority().

  • Parameter: This method does not take any parameter
  • Return Type: Return he maximum priority that a thread in this thread group can have.

Example:

Java
// Java code to demonstrates the
// working of getMaxPriority() method


import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        // checking the maximum priority of parent thread
        System.out.println("Maximum priority of ParentThreadGroup = "
                + g.getMaxPriority());

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting one");
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting two");
    }
}

Output:

Output


10. String getName(): This method returns the name of the group.

Syntax:

final String getName()

  • Parameter: This method does not take any parameter.
  • Return Type: Retrun the name of this thread group.

Example:

Java
// Java program to demonstrates the
// working of getName() method

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting " + t1.getName());
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting " + t2.getName());
    }
}

Output:

Output


11. ThreadGroup getParent(): Returns null if the invoking ThreadGroup object has no parent. Otherwise, it returns the parent of the invoking object.

Syntax:

final ThreadGroup getParent()

  • Parameter: This method does not take any parameter
  • Return Type: Return the parent of this thread group. The top-level thread group is the only thread group whose parent is null.

Example:

Java
// Java program to demonstrates the
// working of getParent() method

import java.lang.*;
class NewThread extends Thread {
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++) {
            try {
                Thread.sleep(10);
            }
            catch (InterruptedException ex) {
                System.out.println("Exception encounterted");
            }
        }
        System.out.println(Thread.currentThread().getName()
                + " finished executing");
    }
} 

public class Geeks{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting " + t1.getName());
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting " + t2.getName());

        // prints the parent ThreadGroup
        // of both parent and child threads
        System.out.println("ParentThreadGroup for " + g.getName() +
                " is " + g.getParent().getName());
        System.out.println("ParentThreadGroup for " + gfg_child.getName()
                + " is " + gfg_child.getParent().getName());
    }
}

Output:

Output


12. void interrupt(): Invokes the interrupt() methods of all threads in the group.

Syntax:

public final void interrupt()

  • Parameter: This method does not take any parameter.
  • Return Type: This method does not return anything.

Example:

Java
// Java program to demonstrates the
// working of interrupt() method

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Thread " + Thread.currentThread().getName()
                        + " interrupted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting " + t1.getName());
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting " + t2.getName());

        // interrupting thread group
        g.interrupt();
    }
}

Output:

Output


13. boolean isDaemon(): Tests if this thread group is a daemon thread group. A daemon thread group is automatically destroyed when its last thread is stopped or its last thread group is destroyed.

Syntax:

public final boolean isDaemon()

  • Parameter: This method does not take any parameter.
  • Return Type: Return true if the group is daemon group. Otherwise it returns false.

Note: This method is now depricated.


14. boolean isDestroyed(): This method tests if this thread group has been destroyed.

Syntax:

public boolean isDestroyed()

  • Parameter: This method does not take any parameter.
  • Return Type: Return true if this object is destroyed.

Note: This method is depricated.


15. void list(): Displays information about the group.

Syntax:

public void list()

  • Parameter: This method does not take any parameter.
  • Return Type: This method does not return anything.

Example:

Java
// Java program to demonstrates 
// the working of  list() method.

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Thread " + Thread.currentThread().getName()
                        + " interrupted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException, Exception
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting " + t1.getName());
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting " + t2.getName());

        // listing contents of parent ThreadGroup
        System.out.println("\nListing parentThreadGroup: " + g.getName()
                + ":");
        // prints information about this thread group
        // to the standard output
        g.list();
    }
}

Output:

Output


16. boolean parentOf(ThreadGroup group): This method tests if this thread group is either the thread group argument or one of its ancestor thread groups.

Syntax:

final boolean parentOf(ThreadGroup group)

  • Parameter: It represent the thread group to be checked if it is a parent of the current thread group.
  • Return Type: Return true if the invoking thread is the parent.

Example:

Java
// Java program to demonstrates
// the working of parentOf() method

import java.lang.*;
class NewThread extends Thread
{
    NewThread(String threadname, ThreadGroup tgob)
    {
        super(tgob, threadname);
        start();
    }
    public void run()
    {

        for (int i = 0; i < 10; i++)
        {
            try
            {
                Thread.sleep(10);
            }
            catch (InterruptedException ex)
            {
                System.out.println("Thread " + Thread.currentThread().getName()
                        + " interrupted");
            }
        }
        System.out.println(Thread.currentThread().getName() +
                " finished executing");
    }
}
public class Geeks
{
    public static void main(String arg[]) throws InterruptedException,
            SecurityException, Exception
    {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        NewThread t1 = new NewThread("one", g);
        System.out.println("Starting " + t1.getName());
        NewThread t2 = new NewThread("two", g);
        System.out.println("Starting " + t2.getName());

        // checking who is parent thread
        if (g.parentOf(gfg_child))
            System.out.println(g.getName() + " is parent of " +
                    gfg_child.getName());
    }
}

Output:

Output


17. void setDaemon(boolean isDaemon): This method changes the daemon status of this thread group. A daemon thread group is automatically destroyed when its last thread is stopped or its last thread group is destroyed.

Syntax:

final void setDaemon(boolean isDaemon)

  • Parameter: It specifies whether the thread is a demon thread or a user thread.
  • Return Type: If isDaemon is true, then the invoking group is flagged as a daemon group.

Note: This method is depricated.


18. void setMaxPriority(int priority): Sets the maximum priority of the invoking group to priority.

Syntax:

final void setMaxPriority(int priority)

  • Parameter: The parameter priority, sets the maximum priority level fot threads in the thread group.
  • Return Type: This method does not return anything.

Example:

Java
// Java program to demonstrates
// the wokring of setMaxPriority() method

import java.lang.*;

class NewThread extends Thread {
    NewThread(String threadname, ThreadGroup tgob) {
        super(tgob, threadname);
    }

    public void run() {
        for (int i = 0; i < 10; i++) {
            try {
                Thread.sleep(10);
            } catch (InterruptedException ex) {
                System.out.println("Thread " + Thread.currentThread().getName() + " interrupted");
            }
        }
        System.out.println(Thread.currentThread().getName() + " [priority = " +
                Thread.currentThread().getPriority() + "] finished executing.");
    }
}

public class Geeks {
    public static void main(String arg[]) throws InterruptedException {
        // creating the thread group
        ThreadGroup g = new ThreadGroup("Parent thread");
        ThreadGroup gfg_child = new ThreadGroup(g, "child thread");

        // Setting the maximum priority for the thread groups
        g.setMaxPriority(Thread.MAX_PRIORITY - 2);
        gfg_child.setMaxPriority(Thread.NORM_PRIORITY);

        // Creating threads
        NewThread t1 = new NewThread("one", g);
         // Ensure priority is within group limit
        t1.setPriority(Math.min(Thread.MAX_PRIORITY, g.getMaxPriority())); 
        System.out.println("Starting " + t1.getName());
        t1.start();

        NewThread t2 = new NewThread("two", gfg_child);
        t2.setPriority(Math.min(Thread.MAX_PRIORITY, gfg_child.getMaxPriority()));  // Ensure priority is within group limit
        System.out.println("Starting " + t2.getName());
        t2.start();
    }
}

Output:

Output


19. String toString(): This method returns a string representation of this Thread group.

Syntax:

public String toString()

  • Parameter: This method does not take any parameter.
  • Return Type: Return String equivalent of the group.

Note: This method is now depricated.



Next Article
Article Tags :
Practice Tags :

Similar Reads