Java并发包里面提供了ThreadGroup类可以帮助我们有效地管理线程组。让我们来看一个生动的例子. Java线程组可以有线程对象或者子线程组组成。也就是说ThreadGroup可以是产生线程树。
让我们看一个简单的例子,这个例子模仿一个搜索任务,将启动10个线程遍历获取指定目录下面的excel文件列表,一旦有一个线程完成遍历,将中断其余的9个任务。
import java.io.File;
import java.util.concurrent.TimeUnit;
public class SearchTask implements Runnable {
private String rootDir;
private SearchResult result;
public SearchTask(String rootDir, SearchResult result) {
super();
this.rootDir = rootDir;
this.result = result;
}
public String getRootDir() {
return rootDir;
}
public void setRootDir(String rootDir) {
this.rootDir = rootDir;
}
public SearchResult getResult() {
return result;
}
public void setResult(SearchResult result) {
this.result = result;
}
@Override
public void run() {
String name = Thread.currentThread().getName();
System.out.printf("Thread %s: Start\n",name);
try{
doSearch(new File(this.rootDir));
result.setTaskName(name);
}catch(InterruptedException e){
System.out.printf("Thread %s: Interrupted\n",name);
return;
}
System.out.printf("Thread %s: End\n",name);
}
private void doSearch(File root) throws InterruptedException{
if(root != null && root.isDirectory()){
TimeUnit.SECONDS.sleep(1);
File[] files = root.listFiles();
if( files != null ){
for(File file : files){
if(file.isFile() && file.getName().endsWith(".xls")){
result.getFiles().add(file.getAbsolutePath());
result.increaseCount();
}else if(file.isDirectory()){
doSearch(file);
}
}
}
}
}
}
package com.concurrent.exercise.threadgroup;
import java.util.ArrayList;
import java.util.List;
public class SearchResult {
private int count = 0;
private String taskName;
private List<String> files = new ArrayList<String>();
public String getTaskName() {
return taskName;
}
public void setTaskName(String taskName) {
this.taskName = taskName;
}
public void setCount(int count) {
this.count = count;
}
public void setFiles(List<String> files) {
this.files = files;
}
public int getCount() {
return count;
}
public void increaseCount() {
count++;
}
public List<String> getFiles(){
return files;
}
}
import java.util.concurrent.TimeUnit;
public class TestThreadGroup {
public static void main(String[] args){
String searchDir = "D:\\";
ThreadGroup threadGroup = new ThreadGroup("Searcher");
for(int i = 0; i < 3; i++){
SearchTask task = new SearchTask(searchDir,new SearchResult());
Thread thread = new Thread(threadGroup, task);
thread.start();
try{
TimeUnit.SECONDS.sleep(2);
}catch(InterruptedException e) {
e.printStackTrace();
}
}
waitFinish(threadGroup);
threadGroup.interrupt();
}
private static void waitFinish(ThreadGroup threadGroup) {
while (threadGroup.activeCount() > 2) {
try {
list(threadGroup);
TimeUnit.SECONDS.sleep(1);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
private static void list(ThreadGroup threadGroup) {
assert(threadGroup != null);
threadGroup.list();
}
}
在启动三个线程后,进入waitFinish方法,当其中一个线程结束后,waitFinish立即对出并调用ThreadGroup终止剩下的线程。
由于ThreadGroup存储了线程和子线程组对象,可以使用ThreadGroup对一组线程执行统一的操作,比如interrupt.
可以参考Java API Doc知道更多关于ThreadGroup的方法。
分享到:
相关推荐
5. **多线程**:Java 2支持多线程编程,通过Thread类和Runnable接口,可以实现并发执行任务。同步机制(如synchronized关键字、wait()和notify()方法)确保了多线程环境下的数据安全。 6. **输入输出流**:Java 2的...
《由浅入深学JAVA》是本人自行编写的CHM格式的java基本教程,内容包括基本概念,JAVA的编译运行环境,类和接口,图形界面和文件操作等,概念和方法都有例程,都是在机器上通过的。附录中介绍JAVA的网络资源。是初雪...
完整版java基础入门教程由浅入深讲解 Java语言编程基础 第13章 多线程(共50页).ppt 完整版java基础入门教程由浅入深讲解 Java语言编程基础 第14章 网络通信(共76页).ppt 完整版java基础入门教程由浅入深讲解 ...
《由浅入深——Java 2自学教程》是一本针对初学者至中级程序员精心编写的Java编程指南。这本书深入浅出地介绍了Java语言的核心概念和技术,旨在帮助读者掌握Java编程的基础,逐步提升到中高级水平。以下是根据书名、...
根据提供的文件信息,“由浅入深学Java—基础、进阶与必做260题”这份资料旨在为初学者提供全面深入的Java学习路径,不仅涵盖了基础知识的学习,还提供了大量的练习题帮助学习者巩固所学知识,并最终成长为一名优秀...
《由浅入深学Java — 基础、进阶与必做260题》是一本详尽的Java学习指南,旨在为初学者至中级开发者提供全面的Java编程技能训练。本书通过清晰的结构和丰富的实践题目,帮助读者逐步掌握Java的核心概念和技术要点。 ...
"由浅入深学Java—基础、进阶与必做260题.pdf"这本书旨在为学习者提供一个全面掌握Java技术的系统化路径,从基础知识到高级概念,再到实战练习,覆盖了Java学习的各个层面。 首先,Java的基础部分涵盖了以下知识点...
"Java基础知识由浅入深"的教程涵盖了Java的多个重要领域,旨在为初学者提供一个全面的入门指南。这个教程包含了以下几个关键部分: 1. **Javase(Java标准版)**: 这是Java的基础,包括语法、类、对象、接口、异常...
这两种方式都可以在 Java 中创建线程,但在本示例中,我们将重点介绍继承 Thread 类的方法。 示例代码 下面是一个简单的 Java 多线程编程示例代码: ```java public class MyThread extends Thread { public void...
《由浅入深学Java:基础、进阶与必做260题》共分为4篇共28章,第1篇从最基本的JDK安装讲起,包括基本语法与数据类型、数组、字符串、程序控制语句、面向对象编程、继承、多态、接口等内容;第2篇讲解了图形界面开发...
### 由浅入深VC多线程编程 #### 一、引言与背景 多线程编程是在软件开发中常用的技术之一,特别是在图形用户界面(GUI)应用中,它能够提高程序的响应性和效率。本文旨在深入浅出地介绍在Visual C++ (VC)环境下如何...
因此,我将直接根据标题《由浅入深学Java-基础、进阶与必做》中提及的知识点来撰写相关知识点。为了确保内容丰富且详细,我将覆盖Java基础、进阶知识和一些常用的Java实践技巧。 Java是目前世界上使用最广泛的编程...
由浅入深学Java教程。 由浅入深学Java(一本java入门教材)
这份“由浅入深之java习题全汇总”旨在帮助初学者系统地掌握Java的基础知识和实际应用,涵盖从安装开发环境到编写代码的各种技能。 首先,安装JDK是Java开发的第一步,它包含了Java编译器和运行时环境。配置环境...
内含java方面的知识,如:java语法基础,JDK5新特性,面向对象概述,面向对象程序设计,数据库,类的高级特征,数据结构与算法,网络,高级IO流等···是一套完整java教材。希望给大家带去帮助。 谢谢
- **线程创建**:了解通过继承Thread类和实现Runnable接口两种方式创建线程。 - **同步机制**:理解synchronized关键字的作用;掌握Lock接口及其实现类ReentrantLock的使用方法。 - **并发工具类**:熟悉...
Java面试宝典,从最基础的javaSE到Javaweb、设计模式、jvm基础知识、linux、前端框架、mysql和oracle数据库。 框架部分:spring框架、springMVC、shiro、Mybatis、struts2 技术:redis、消息队列ActiveMq、dubbo框架...
绑定状况下,则顾名思义,即某个线程固定的"绑"在一个轻进程之上。被绑定的线程具有较高的响应速度,这是因为CPU时间片的调度是面向轻进程的,绑定的线程可以保证在需要的时候它总有一个轻进程可用。