java--ThreadGroup详解

简介

ThreadGroup(线程组)是Java中用于组织线程的一种结构,它提供了对线程的层次化管理。通过线程组,可以将一组线程组织成一个树状结构,方便对线程进行统一控制和管理。

ThreadGroup的一些主要特点和用法:

  • 层次结构:线程组能够形成层次结构,具有父子关系。每个线程组都有一个父线程组,除了主线程组(默认的顶级线程组)外。通过层次结构,可以方便地对整个线程组进行组织和管理。
  • 统一控制: 通过线程组,可以对整个线程组的属性进行统一的控制,如设置线程组的优先级、守护状态(daemon)、未捕获异常处理器(uncaught exception handler)等。这些设置会自动应用于该线程组中的所有线程。
  • 异常处理: 线程组可以设置一个统一的未捕获异常处理器,用于处理线程组中的线程产生的未捕获异常。这可以有效地集中处理线程组中的异常情况。
  • 线程组的活动监控:ThreadGroup类还提供了一些方法来获取有关线程组中线程的信息,如活动线程数、子线程组数等

线程组的基本使用

创建线程组将两个线程放入到线程组中

csharp 复制代码
package Future类;
​
public class demo333 {
    public static void main(String[] args) {
        ThreadGroup group= new ThreadGroup("线程组");
        Thread t1=new Thread(group,new myrun(),"线程1");
        Thread t2=new Thread(group,new myrun(),"线程2");
        t1.start();
        t2.start();
​
        System.out.println("Number of active threads in the group: " + group.activeCount());
        System.out.println("Thread group name: " + group.getName());
​
        group.list();
​
    }
}
class myrun implements Runnable{
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"running了");
        try {
            Thread.sleep(200);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
        System.out.println(Thread.currentThread().getName() + " is completed.");
    }
}

运行结果:

Number of active threads in the group: 2 线程1running了 Thread group name: 线程组 线程2running了 java.lang.ThreadGroup[name=线程组,maxpri=10] Thread[线程1,5,线程组] Thread[线程2,5,线程组] 线程1 is completed. 线程2 is completed.

通过activeCount()方法和getName()方法,可以获取线程组中活动线程的数量和线程组的名称

通过list()方法,可以在控制台上列出线程组中的线程和线程组的信息

线程池中使用线程组

线程组可以帮助我们管理相关联的线程,进行统一的控制和管理。 特别适合用于对一组线程进行集中管理的场景,例如线程池任务中的线程归类、通过异常处理器处理一组线程中的异常等

结合线程池使用线程组可以更好地管理和控制线程的执行。线程池可以提供线程的重用和资源管理,而线程组可以提供对线程的蹭层次化组织和管理;下面是结合线程池使用线程组的举例:

java 复制代码
package Future类;
​
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadFactory;
​
public class dmmo444 {
    public static void main(String[] args) {
        ThreadGroup group=new ThreadGroup("myThreadgroup");
        ExecutorService executorService= Executors.newFixedThreadPool(2,new ThreadFactoryWithThreadGroup(group));
​
        executorService.execute(new myruns("tesk1"));
        executorService.execute(new myruns("tesk2"));
        executorService.execute(new myruns("tesk3"));
​
        executorService.shutdown();
    }
}
class myruns implements Runnable{
​
    private String name;
​
    public myruns(String name) {
        this.name = name;
    }
​
    @Override
    public void run() {
        System.out.println("Executing name"+name+",线程组的名字为"+Thread.currentThread().getThreadGroup().getName());
        //添加具体执行的操作
    }
}
class ThreadFactoryWithThreadGroup implements ThreadFactory{
    private ThreadGroup threadGroup;
​
    public ThreadFactoryWithThreadGroup(ThreadGroup threadGroup) {
        this.threadGroup = threadGroup;
    }
​
    @Override
    public Thread newThread(Runnable r) {
        return new Thread(threadGroup,r);
    }
}

运行结果:

Executing nametesk1,线程组的名字为myThreadgroup Executing nametesk2,线程组的名字为myThreadgroup Executing nametesk3,线程组的名字为myThreadgroup

我们创建了一个包含两个线程的线程池,并且为线程池指定了一个自定义的ThreadFactory(线程工厂),该工厂类使用线程组作为线程的创建者。

在主线程中,我们创建了一个名为"MyThreadGroup"的线程组,并为线程池提供了该线程组的实例。

然后,我们向线程池提交了三个Runnable任务,并通过不同的线程执行。在任务的run()方法中,我们可以看到线程所属的线程组名字是"MyThreadGroup"

通过结合线程池和线程组的使用,我们可以更好地管理和控制线程的创建、执行和销毁。线程池提供了线程的重用和资源管理,而线程组提供了对线程的组织和管理能力。这种结合使用可以更好地满足多线程编程中的需求,减少了对线程的手动维护,

相关推荐
万亿少女的梦1685 分钟前
基于Spring Boot的网络购物商城的设计与实现
java·spring boot·后端
醒了就刷牙32 分钟前
黑马Java面试教程_P9_MySQL
java·mysql·面试
m0_7482336438 分钟前
SQL数组常用函数记录(Map篇)
java·数据库·sql
编程爱好者熊浪2 小时前
JAVA HTTP压缩数据
java
吴冰_hogan2 小时前
JVM(Java虚拟机)的组成部分详解
java·开发语言·jvm
开心工作室_kaic2 小时前
springboot485基于springboot的宠物健康顾问系统(论文+源码)_kaic
spring boot·后端·宠物
0zxm2 小时前
08 Django - Django媒体文件&静态文件&文件上传
数据库·后端·python·django·sqlite
白宇横流学长3 小时前
基于java出租车计价器设计与实现【源码+文档+部署讲解】
java·开发语言
数据小爬虫@5 小时前
Java爬虫实战:深度解析Lazada商品详情
java·开发语言
咕德猫宁丶5 小时前
探秘Xss:原理、类型与防范全解析
java·网络·xss