线程组用于组织和管理多个线程,支持统一操作如中断、查看活动线程数等。创建时可指定所属组,未指定则默认加入父线程组。通过ThreadGroup的interrupt()方法可中断组内所有线程,activeCount()获取活动线程数量,enumerate()将线程复制到数组遍历。线程组支持树形结构,可嵌套子组,便于复杂管理,并可配合安全管理器限制操作。尽管现代并发编程中ExecutorService更常用,但线程组在需要集中控制线程的场景下仍有实用价值。

在Java中,线程组(ThreadGroup)提供了一种组织和管理多个线程的机制。通过线程组,可以对一组线程进行统一操作,比如统一设置优先级、中断所有线程或监控线程状态。合理使用线程组有助于提升多线程程序的可维护性和控制能力。
创建和使用线程组
Java中的ThreadGroup类允许将线程分组管理。创建线程时可以指定所属的线程组,若未指定,则默认加入父线程所在的组。
示例:创建线程组并添加线程
   ThreadGroup group = new ThreadGroup(“Download-Group”);
   Thread t1 = new Thread(group, () -> {
       System.out.println(“线程 ” + Thread.currentThread().getName() + ” 正在下载…”);
       try { Thread.sleep(2000); } catch (InterruptedException e) { }
   }, “Downloader-1”);
    Thread t2 = new Thread(group, () -> {
       System.out.println(“线程 ” + Thread.currentThread().getName() + ” 正在校验…”);
       try { Thread.sleep(1500); } catch (InterruptedException e) { }
   }, “Downloader-2”);
    t1.start();
   t2.start(); 
对线程组进行批量操作
线程组支持对组内所有线程进行统一操作,例如中断、查看活动线程数等。
常用方法包括:
- interrupt():中断组内所有活动线程
- activeCount():获取当前活动线程数量
- enumerate(Thread[] list):将组内线程复制到数组中以便遍历
   // 中断整个组
   group.interrupt();
    // 查看当前活动线程数
   System.out.println(“活动线程数: ” + group.activeCount());
    // 列出所有线程
   Thread[] threads = new Thread[group.activeCount()];
   group.enumerate(threads);
   for (Thread t : threads) {
       System.out.println(“运行中的线程: ” + t.getName() + “, 状态: ” + t.getState());
   } 
线程组的层级结构与安全管理
线程组支持树形结构,一个组可以包含子组,便于构建复杂的管理模型。同时,线程组可以配合安全管理器限制某些操作,如防止随意修改线程组。
立即进入“豆包AI人工智官网入口”;
立即学习“豆包AI人工智能在线问答入口”;
注意:如果不显式设置安全管理器,大多数权限检查不会生效,但结构上的父子关系依然存在。
示例:嵌套线程组
   ThreadGroup parent = new ThreadGroup(“Parent-Group”);
   ThreadGroup child = new ThreadGroup(parent, “Child-Group”);
    Thread t3 = new Thread(child, () -> {
       System.out.println(“子组中的线程执行”);
   });
   t3.start(); 
基本上就这些。线程组虽然在现代并发编程中不如ExecutorService常用,但在需要集中控制一批线程的场景下仍有实用价值,特别是日志归类、任务隔离或批量终止时。不复杂但容易忽略。


