`
臻是二哥
  • 浏览: 188435 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
博客专栏
Group-logo
Java技术分享
浏览量:0
社区版块
存档分类
最新评论

JAVA并发-线程状态和线程组

 
阅读更多
在Java中,线程有6种基本状态,理解这6种基本状态之间的关系可以让我们对多线程有更好的理解.如下图所示:


在Java中,所有的线程都存在于线程组中,每个线程组中可以包含多个线程或者线程组.运行下面的程序,从结果中可以看出默认的线程组层次结构.
system是Java中的根线程组.从system开始,有一层层的线程和线程组.类似目录结构.

/**
 * Java线程组的结构,见运行结果
 * @author Administrator
 *
 */
public class Main {
	public static void main(String [] args) {
		Thread.currentThread().getThreadGroup().getParent().list();
		Thread.currentThread().getThreadGroup().list();
	}	
}

下面的程序中实现当一个线程运行结束时,结束其他的线程.这个需求也可以用Executor框架来完成.不过显然用线程组是容易的.
/**
 * 实现当一个线程运行结束时,结束其他的线程
 * @author Administrator
 *
 */
public class Main {
	public static void main(String [] args) throws InterruptedException{
		ThreadGroup threadGroup = new ThreadGroup("Searcher");
		
		
		for(int i=0;i<5;i++){
			new Thread(threadGroup,new Task(),"t"+(i+1)).start();
		}
		
		System.out.println(threadGroup.activeCount());
		threadGroup.list();
		
		Thread.sleep(1000);
		waitFinish(threadGroup);
		
		threadGroup.interrupt();
	}
	
	private static void waitFinish(ThreadGroup threadGroup) {
		while (threadGroup.activeCount()>5) {
		}
		System.out.println("有一个结束了");
	}
}

class Task implements Runnable {
	public void run() {
		for(int i=0;i<Integer.MAX_VALUE/100;i++){
			System.out.print(i+" ");
			if(Thread.currentThread().isInterrupted())
				break;
		}
		System.out.println(Thread.currentThread().getName());
	}
}


在JAVA多线程编程时,通过为一个线程对象或者一个线程类设置UncaughtExceptionHandler可以实现捕获run()方法内的运行时异常.
下面的例子是捕获线程内的运行时异常:

public class Main {
	public static void main(String [] args) {
		
		for(int i=0;i<3;i++){
			final int flag=i;
			MyThread myThread=new MyThread();
			myThread.setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
				@Override
				public void uncaughtException(Thread arg0, Throwable arg1) {
					// TODO Auto-generated method stub
					System.out.println("mythead发生异常!"+flag);
					
				}
			});
			myTHread.start();
		}
	}
}

class MyThread extends Thread{
	public void run(){
		String str=null;
		try {
			Thread.sleep(2000);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		System.out.println(str.hashCode());
	}
}























  • 大小: 155.9 KB
0
2
分享到:
评论

相关推荐

    Java 多线程与并发(2-26)Java 并发 - 线程基础.pdf

    3. `CyclicBarrier`和`CountDownLatch`: 这些是高级并发工具,用于控制一组线程的同步行为。 4. `Semaphore`: 信号量用于控制对有限资源的访问权限,可以限制同时访问的线程数量。 理解线程基础对于编写高效、安全...

    JAVA线程高级-线程按序交替执行

    - 线程有新建、就绪、运行、阻塞和死亡五种状态。了解这些状态有助于理解线程的执行流程。 - `Thread.sleep()`方法可以使当前线程进入阻塞状态,到指定时间后自动恢复。 - `join()`方法让调用的线程等待目标线程...

    北大Java--多线程

    - 线程组是线程的容器,可以用于管理和控制一组线程,如设定优先级,启动、中断或检查线程状态。 8. **并发现象**: - 并发是现代计算机系统中的常态,如操作系统同时处理多个进程,人体的多个器官协同工作,多...

    java编程 ---线程

    在Java编程中,线程是程序执行的一个独立路径,允许多个任务在同一程序中并发执行。了解线程的相关概念对于开发高效、响应迅速的软件至关重要。 **1. 相关概念理解** 程序是一组静态的代码,而进程是这些代码在内存...

    Java-Thread-Affinity,将Java线程绑定到给定的内核.zip

    Java线程亲和性(Thread Affinity)是一个高级并发编程概念,主要涉及到操作系统调度和硬件资源的优化。在多核处理器系统中,线程亲和性允许开发者指定某个线程应该运行在哪个特定的处理器核心上,从而提高性能、...

    java常见面试题---线程篇

    在Java编程领域,线程是并发处理的核心概念,它允许程序在同一时间...理解并熟练掌握这些知识点,对于解决Java并发问题和优化多线程应用至关重要。在实际工作中,还需要关注线程安全、性能优化和代码可维护性等问题。

    Java并发编程-3.pdf

    Java并发编程中的多线程协作机制 在 Java 并发编程中,多线程协作机制是非常重要的一部分。多线程协作机制是指在多线程编程中,多个线程之间如何协作、同步和通信,以达到共同完成某个任务的目的。Java 提供了多种...

    java课件-5-多线程

    Java并发API的另一个亮点是Future和Callable接口,它们提供了一种异步计算的模型。Future代表一个异步操作的结果,而Callable允许我们在新的线程中执行计算并返回结果。 在压缩包的文件列表中,"5_多线程"可能包含...

    黑马程序员_张孝祥_Java多线程与并发库 视频+代码+资料

    5. **并发容器**:Java并发库还提供了一些线程安全的集合类,如`ConcurrentHashMap`、`CopyOnWriteArrayList`等,这些容器可以在高并发场景下安全地使用。 通过以上知识点的学习,开发者可以深入理解Java多线程编程...

    JAVA并发编程实践-线程对象与组合对象-学习笔记

    使用java.util.concurrent类库构造安全的并发应用程序的基础。共享其实就是某一线程的数据改变对其它线程可见,否则就会出现脏数据。

    JAVA并发编程实践-线程的关闭与取消-学习笔记

    在Java并发编程中,线程的关闭和取消是一项重要的任务,因为不正确的处理可能导致数据不一致、资源泄漏等问题。在Java中,强制停止线程并不是一个推荐的做法,因为这可能会导致系统状态的不稳定。传统的`Thread.stop...

    Java并发编程常识-梁飞.rar

    Java并发编程的核心组件包括线程、锁、同步、并发集合和并发工具类。线程是并发的基本执行单元,Java提供了Thread类来创建和控制线程。锁用于在多线程环境下控制共享资源的访问,Java提供了synchronized关键字和java...

    java多线程并发

    `ExecutorService`是Java并发工具包中的核心接口之一,它定义了一组线程池管理的方法,可以帮助我们更加高效地管理和调度线程。 - **固定大小的线程池**:`newFixedThreadPool(int nThreads)`创建一个可重用的固定...

    13-Java并发编程学习宝典.zip

    "13-Java并发编程学习宝典.zip" 包含了一系列关于Java并发编程的学习资源,旨在帮助开发者掌握多线程编程的核心技术和最佳实践。以下是这些资源所涵盖的关键知识点: 1. **多线程基础** - "03 多线程开发如此简单—...

    java经典多线程面试题

    在Java中,多线程是一种非常重要的编程概念,它允许在单一程序中同时运行多个线程来执行不同的任务,从而提高程序的执行效率和资源利用率。Java提供了丰富的API和语言特性来支持多线程编程。以下是一些经典的多线程...

    java多线程查询数据库

    本文将详细探讨如何利用Java的多线程技术和线程池来实现并发查询数据库,以及相关的文件`BatchDataUtil.java`和`BatchDataRunnable.java`可能涉及的关键知识点。 ### 1. 多线程并发查询 多线程并发查询允许我们将一...

    java并发(二十四)多线程结果组装

    Java的并发集合如`ConcurrentHashMap`、`ConcurrentLinkedQueue`等提供了线程安全的插入和读取操作,避免了同步问题。 8. **异常处理**:在多线程环境下,异常处理是必须考虑的问题。`Future.get()`方法会抛出一个`...

    Java并发编程设计原则和模式

    本资料“Java并发编程设计原则和模式”深入探讨了如何在Java环境中有效地进行并发处理,以充分利用系统资源并避免潜在的并发问题。 一、并发编程基础 并发是指两个或多个操作在同一时间段内执行,但并不意味着这些...

    《java 并发编程实战高清PDF版》

    在Java并发编程中,多线程是核心概念之一。多线程允许程序同时执行多个任务,从而充分利用系统资源,提高程序性能。然而,多线程编程也带来了同步和竞态条件等问题,这需要开发者具备良好的线程管理和同步机制的知识...

Global site tag (gtag.js) - Google Analytics