java多线程
2.3 线程池
创建线程是需要一定的代价的,因此,在一个应用程序中创建过多的线程会占用大量系统资源,降低程序的执行速度,甚至造成java虚拟机的崩溃。使用线程池主要出于两种目的,首先,一个线程池会维护一定数量的线程,当新的多线程任务到来后,线程池会寻求一个空闲线程执行任务,如果线程池中没有可用的空闲线程,那么线程池等待(不同线程池的动作不同)直至有新的空闲线程的产生,如果线程池中的某个线程执行结束,那么这个线程不会立即销毁退出,它会作为一个空闲线程放入线程池中,以便执行其他的线程任务。其次,使用线程池可以减少系统内并发线程的数目,防止系统因创建过多线程而导致的性能下降或崩溃。一般情况下,系统中存在大量的生命期较短的线程,应当使用线程池。
2.3.1 创建线程池
线程池的创建需要调用Executor的一些静态工厂方法。Executor的newCachedThreadPool可用创建一个缓冲的线程池,此类线程池,在系统需要的时候会创建新线程,空闲线程等待指定时间后仍未被使用将会被释放(具体开启多少线程,由系统决定)。newFixedThreadPool用来创建一个指定大小的线程池。newSingleThreadExecutor用来生成单一线程的线程池,这个线程池会按照顺序一个接一个的执行线程任务。newScheduleThreadPool用于执行固定频率的线程任务(替代Timer)。newSingleThreadScheduleExecutor用来创建固定频率任务的单线程线程池。
在线程池创建后,任务执行完成后使用shutDown方法释放线程池资源。
Demo2-9将从0-99求和的程序使用了线程池的方法进行了修改。在主线程中创建了线程池,然后将计算任务分发到下面的子线程,最后主线程统计计算任务输出结果。在这个过程中每个子线程都输出了自己线程的名字,可以便于我们观察到底是哪个线程执行了当前线程任务,从结果中不难看出,很多线程执行了多个任务。此外,调用线程池的shutDown方法,并不会造成阻塞,在主线程中需要设置专门的同步策略(这里用的是CountDownLatch)来等待所有子线程结束。当线程池调用shutDown方法后,线程池并不会立即关闭,而是在线程池没有任务执行的情况下才关闭管辖的所有线程,可以通过调用shutDownNow方法即时关闭线程池。此外ThreadPoolExecutor类可以包装一个ExecutorServer类,并提供了一些对线程池的附加操作(他们之间的关系同Thread与FutureTask的关系相似),可以查阅java API获取更多的知识。
Demo2-9 线程池示例
package com.upc.upcgrid.guan.advancedJava.chapter02;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
class OnceComputePool implements Runnable{
private int begin;
private int end;
private CountDownLatch latch;
private int sum = 0;
public OnceComputePool(int begin,int end) {
this.begin = begin;
this.end = end;
}
public OnceComputePool(int begin, int end, CountDownLatch latch) {
this.begin = begin;
this.end = end;
this.latch = latch;
}
@Override
public void run() {
for(int i = begin; i < end ; i++)
sum += i;
System.err.println(Thread.currentThread().getName());
latch.countDown();
}
public int getSum()
{
return sum;
}
}
public class ThreadPool {
public static void main(String[] args) throws InterruptedException {
final int MAX_THREAD_SIZE = 10;
ExecutorService pool = Executors.newCachedThreadPool();
CountDownLatch latch = new CountDownLatch(MAX_THREAD_SIZE);
List<OnceComputePool> tasks = new ArrayList<OnceComputePool>();
int sum = 0;
for(int i = 0 ;i < MAX_THREAD_SIZE ;i++)
{
OnceComputePool task = new OnceComputePool(i*10, (i+1)*10,latch);
tasks.add(task);
pool.submit(task);
}
pool.shutdown();
System.err.println(Thread.currentThread().getName());
latch.await();
for(OnceComputePool task: tasks)
sum += task.getSum();
System.err.println(sum);
System.err.println(((ThreadPoolExecutor) pool).getLargestPoolSize());
}
}
Demo2-9 的执行结果
pool-1-thread-1
pool-1-thread-1
pool-1-thread-1
pool-1-thread-3
main
pool-1-thread-2
pool-1-thread-5
pool-1-thread-4
pool-1-thread-7
pool-1-thread-6
4950
7
2.3.2 使用线程池执行定期任务
ScheduleExecutorServer接口可以用来执行预定义任务。使用Executors类的newScheduledThreadPool和newSingleThreadSchedulePool可以获得实现了ScheduleExecutorServer接口的对象。
ScheduleExecutorServer类中的schedule方法将在指定时间后执行某一任务,scheduleAtFixedRate方法用来执行周期性任务。Demo2-10给出了一个调度线程池的例子,这个例子每隔1s钟就执行一次输出当前时间的操作。定时的线程池可以作为Timer的替代方案,Demo2-11给出了使用Timer实现的相同功能的定时任务。
Demo2-10 定期执行任务
package com.upc.upcgrid.guan.advancedJava.chapter02;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class SchedulePool {
public static void main(String[] args) throws InterruptedException {
ScheduledExecutorService timer = Executors.newSingleThreadScheduledExecutor();
timer.scheduleAtFixedRate(new Runnable() {
SimpleDateFormat formate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
@Override
public void run() {
System.out.println(formate.format(new Date()));
}
}, 100,1000,TimeUnit.MILLISECONDS);
Thread.sleep(5000);
timer.shutdown();
}
}
Demo2-11 执行结果
2011-05-18 10:24:40
2011-05-18 10:24:41
2011-05-18 10:24:42
2011-05-18 10:24:43
2011-05-18 10:24:44
Demo2-11 使用Timer完成同样定时功能
package com.upc.upcgrid.guan.advancedJava.chapter02;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;
public class ScheduleTimer {
public static void main(String[] args) throws InterruptedException {
Timer timer = new Timer ();
timer.schedule(new TimerTask() {
SimpleDateFormat formate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
@Override
public void run() {
System.out.println(formate.format(new Date()));
}
},100, 1000);
Thread.sleep(5000);
timer.cancel();
}
}
分享到:
相关推荐
java线程池使用后到底要关闭吗 java线程池是一种高效的并发编程技术,可以帮助开发者更好地管理线程资源,提高系统的性能和可靠性。然而,在使用java线程池时,一个常见的问题是:使用完线程池后到底要不要关闭?...
"Java 线程池完整代码解析" Java 线程池是 Java 语言中的一个重要概念,它允许开发者创建和管理多个线程,以提高程序的并发性和性能。下面是对给定文件的解析,包括 title、description、标签和部分内容的解析。 ...
Java线程池是一种高效管理线程的技术,它允许开发者预定义一组线程,根据任务的需要灵活调度,而不是每次需要执行任务时都创建新的线程。这种设计模式大大提高了系统的性能,减少了系统资源的消耗,特别是在高并发...
java线程池知识、
Java线程池是一种高效管理线程资源的工具,它能够帮助开发者有效地控制并调度线程,从而提升系统性能,减少系统资源的浪费。在Java中,`ExecutorService`接口是线程池的主要入口,它是`java.util.concurrent`包的一...
Java线程池是Java并发编程中的重要组件,它能够有效地管理和复用线程,从而提高程序的执行效率和降低资源消耗。在JDK 1.5版本之前,Java对线程池的支持非常有限,而在JDK 1.5之后,加入了java.util.concurrent包,...
Java线程池(ThreadPool)是Java并发编程中的一个重要概念,它可以帮助我们有效地管理和控制并发执行的任务,从而提高系统的效率和稳定性。线程池通过复用已存在的线程,避免了频繁创建和销毁线程带来的开销,同时也...
### 自定义实现Java线程池 #### 一、概述 在深入探讨自定义Java线程池之前,我们先简要回顾一下线程池的基本概念及其重要性。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动...
Java线程池是Java并发编程中的重要组成部分,它在多线程和高并发场景下扮演着关键角色。本文将深入探讨Java线程池的源码分析,并对比不同类型的线程池,以帮助开发者更好地理解和利用这一强大的工具。 首先,我们要...
Java线程池是一种高效管理线程资源的工具,它的出现是为了应对多线程编程中频繁创建和销毁线程带来的性能开销以及资源消耗。在Java中,通过使用线程池,我们可以预先创建一定数量的线程,这些线程在空闲时可以被复用...
Java线程池是Java并发编程中的重要组成部分,它允许开发者管理多个线程并有效地调度任务。线程池通过ThreadPoolExecutor类实现,这是一个高度可配置的工具,能够根据具体需求定制线程的创建、管理和销毁策略。 ...
简单的线程池程序+中文文档 包结构: com.tangkai.threadpool --SimpleThread.java 工作线程 --TestThreadPool.java 程序入口 --ThreadPoolManager.java 线程池管理类
Java线程池是一种高级的多线程处理框架,它是Java并发编程中非常重要的一个组件。线程池的原理和实现涉及到操作系统调度、内存管理和并发控制等多个方面。理解线程池的工作原理有助于优化程序性能,避免过度创建和...
2.然后根据提示运行java命令执行示例程序,观看线程池的运行结果 目标:Java中多线程技术是一个难点,但是也是一个核心技术。因为Java本身就是一个多线程语言。本人目前在给46班讲授Swing的网络编程--使用Swing来...
### Java线程池详解 #### 一、线程与线程池的概念 在Java中,线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。一个进程(例如某个Java应用)至少有一个线程,如果线程...
Java线程池是一种高效管理并发任务的机制,它允许开发者预先配置一定数量的线程,以便在处理多个并发任务时能有效地复用这些线程,从而避免了频繁创建和销毁线程带来的开销。在Java中,`java.util.concurrent`包下的...
基于Java线程池技术实现Knock Knock游戏项目.zip 基于Java线程池技术实现Knock Knock游戏项目.zip 基于Java线程池技术实现Knock Knock游戏项目.zip 基于Java线程池技术实现Knock Knock游戏项目.zip 基于Java线程池...
Java线程池是一种高效利用系统资源、管理并发执行任务的机制。它的原理是通过预先创建一组线程,这些线程在任务到来时可以立即执行,而不是每次需要执行任务时都新建线程,从而降低了线程创建和销毁带来的开销。...
Java线程池是Java并发编程中的重要组成部分,它允许开发者高效地管理多个并发执行的线程,有效地控制系统的资源消耗,提高系统性能和稳定性。在Java中,`java.util.concurrent`包提供了`ExecutorService`接口及其...
讲述了java线程池的优点,参数,6种线程池的使用场景,线程池用到的handler,线程任务的提交方式等等。