`
zhuyuyuseu
  • 浏览: 9279 次
  • 性别: Icon_minigender_1
  • 来自: 南通
社区版块
存档分类
最新评论

由浅入深Java线程之ThreadGroup

    博客分类:
  • Java
阅读更多
  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的方法。

分享到:
评论

相关推荐

    由浅入深——Java 2自学教程 配书光盘.rar

    5. **多线程**:Java 2支持多线程编程,通过Thread类和Runnable接口,可以实现并发执行任务。同步机制(如synchronized关键字、wait()和notify()方法)确保了多线程环境下的数据安全。 6. **输入输出流**:Java 2的...

    《由浅入深学JAVA》 JAVA入门教程

    《由浅入深学JAVA》是本人自行编写的CHM格式的java基本教程,内容包括基本概念,JAVA的编译运行环境,类和接口,图形界面和文件操作等,概念和方法都有例程,都是在机器上通过的。附录中介绍JAVA的网络资源。是初雪...

    完整版java基础入门教程由浅入深讲解 Java语言编程基础 含辅助PPT资料 全套PPT课件 共15个章节.rar

    完整版java基础入门教程由浅入深讲解 Java语言编程基础 第13章 多线程(共50页).ppt 完整版java基础入门教程由浅入深讲解 Java语言编程基础 第14章 网络通信(共76页).ppt 完整版java基础入门教程由浅入深讲解 ...

    由浅入深——Java 2自学教程.rar

    《由浅入深——Java 2自学教程》是一本针对初学者至中级程序员精心编写的Java编程指南。这本书深入浅出地介绍了Java语言的核心概念和技术,旨在帮助读者掌握Java编程的基础,逐步提升到中高级水平。以下是根据书名、...

    由浅入深学Java—基础、进阶与必做260题

    根据提供的文件信息,“由浅入深学Java—基础、进阶与必做260题”这份资料旨在为初学者提供全面深入的Java学习路径,不仅涵盖了基础知识的学习,还提供了大量的练习题帮助学习者巩固所学知识,并最终成长为一名优秀...

    由浅入深学Java — 基础、进阶与必做260题 高清 PDF

    《由浅入深学Java — 基础、进阶与必做260题》是一本详尽的Java学习指南,旨在为初学者至中级开发者提供全面的Java编程技能训练。本书通过清晰的结构和丰富的实践题目,帮助读者逐步掌握Java的核心概念和技术要点。 ...

    由浅入深学Java—基础、进阶与必做260题.pdf

    "由浅入深学Java—基础、进阶与必做260题.pdf"这本书旨在为学习者提供一个全面掌握Java技术的系统化路径,从基础知识到高级概念,再到实战练习,覆盖了Java学习的各个层面。 首先,Java的基础部分涵盖了以下知识点...

    Java基础知识由浅入深

    "Java基础知识由浅入深"的教程涵盖了Java的多个重要领域,旨在为初学者提供一个全面的入门指南。这个教程包含了以下几个关键部分: 1. **Javase(Java标准版)**: 这是Java的基础,包括语法、类、对象、接口、异常...

    java多线程编程源码范例和详细说明(由浅入深,深度解读在资料后半部分).docx

    这两种方式都可以在 Java 中创建线程,但在本示例中,我们将重点介绍继承 Thread 类的方法。 示例代码 下面是一个简单的 Java 多线程编程示例代码: ```java public class MyThread extends Thread { public void...

    由浅入深学Java—基础、进阶与必做260题 高清pdf版

    《由浅入深学Java:基础、进阶与必做260题》共分为4篇共28章,第1篇从最基本的JDK安装讲起,包括基本语法与数据类型、数组、字符串、程序控制语句、面向对象编程、继承、多态、接口等内容;第2篇讲解了图形界面开发...

    由浅入深VC多线程编程

    ### 由浅入深VC多线程编程 #### 一、引言与背景 多线程编程是在软件开发中常用的技术之一,特别是在图形用户界面(GUI)应用中,它能够提高程序的响应性和效率。本文旨在深入浅出地介绍在Visual C++ (VC)环境下如何...

    由浅入深学Java-基础、进阶与必做

    因此,我将直接根据标题《由浅入深学Java-基础、进阶与必做》中提及的知识点来撰写相关知识点。为了确保内容丰富且详细,我将覆盖Java基础、进阶知识和一些常用的Java实践技巧。 Java是目前世界上使用最广泛的编程...

    由浅入深学Java(一本java入门教材)

    由浅入深学Java教程。 由浅入深学Java(一本java入门教材)

    由浅入深之java习题全汇总

    这份“由浅入深之java习题全汇总”旨在帮助初学者系统地掌握Java的基础知识和实际应用,涵盖从安装开发环境到编写代码的各种技能。 首先,安装JDK是Java开发的第一步,它包含了Java编译器和运行时环境。配置环境...

    java教材 由浅入深

    内含java方面的知识,如:java语法基础,JDK5新特性,面向对象概述,面向对象程序设计,数据库,类的高级特征,数据结构与算法,网络,高级IO流等···是一套完整java教材。希望给大家带去帮助。 谢谢

    由浅入深学Java—基础、进阶与必做260题高清版

    - **线程创建**:了解通过继承Thread类和实现Runnable接口两种方式创建线程。 - **同步机制**:理解synchronized关键字的作用;掌握Lock接口及其实现类ReentrantLock的使用方法。 - **并发工具类**:熟悉...

    Java面试宝典-由浅入深-涵盖技术广

    Java面试宝典,从最基础的javaSE到Javaweb、设计模式、jvm基础知识、linux、前端框架、mysql和oracle数据库。 框架部分:spring框架、springMVC、shiro、Mybatis、struts2 技术:redis、消息队列ActiveMq、dubbo框架...

    由浅入深Linux下pthread线程库介绍[归类].pdf

    绑定状况下,则顾名思义,即某个线程固定的"绑"在一个轻进程之上。被绑定的线程具有较高的响应速度,这是因为CPU时间片的调度是面向轻进程的,绑定的线程可以保证在需要的时候它总有一个轻进程可用。

Global site tag (gtag.js) - Google Analytics