转自:http://blog.csdn.net/ghsau/article/details/7443324
自JDK5之后,Java推出了一个并发包,java.util.concurrent,在Java开发中,我们接触到了好多池的技术,String类的对象池、Integer的共享池、连接数据库的连接池、Struts1.3的对象池等等,池的最终目的都是节约资源,以更小的开销做更多的事情,从而提高性能。
我们的web项目都是部署在服务器上,浏览器端的每一个request就是一个线程,那么服务器需要并发的处理多个请求,就需要线程池技术,下面来看一下Java并发包下如何创建线程池。
1.创建一个可重用固定线程集合的线程池,以共享的无界队列方式来运行这些线程。
-
ExecutorServicethreadPool=Executors.newFixedThreadPool(3);
2.创建一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们。
-
ExecutorServicethreadPool=Executors.newCachedThreadPool();
3.创建一个使用单个 worker 线程的 Executor,以无界队列方式来运行该线程。
-
ExecutorServicethreadPool=Executors.newSingleThreadExecutor();
4. 创建一个可安排在给定延迟后运行命令或者定期地执行的线程池。
-
ScheduledExecutorServicethreadPool=Executors.newScheduledThreadPool(3);
每种线程池都有不同的使用场景,下面看一下这四种线程池使用起来有什么不同。
1. FixedThreadPool
-
importjava.util.concurrent.ExecutorService;
-
importjava.util.concurrent.Executors;
-
publicclassThreadPoolTest{
-
publicstaticvoidmain(String[]args){
-
ExecutorServicethreadPool=Executors.newFixedThreadPool(3);
-
for(inti=1;i<5;i++){
-
finalinttaskID=i;
-
threadPool.execute(newRunnable(){
-
publicvoidrun(){
-
for(inti=1;i<5;i++){
-
try{
-
Thread.sleep(20);
-
}catch(InterruptedExceptione){
-
e.printStackTrace();
-
}
-
System.out.println("第"+taskID+"次任务的第"+i+"次执行");
-
}
-
}
-
});
-
}
-
threadPool.shutdown();
-
}
-
}
输出结果:
-
第1次任务的第1次执行
-
第2次任务的第1次执行
-
第3次任务的第1次执行
-
第2次任务的第2次执行
-
第3次任务的第2次执行
-
第1次任务的第2次执行
-
第3次任务的第3次执行
-
第1次任务的第3次执行
-
第2次任务的第3次执行
-
第3次任务的第4次执行
-
第2次任务的第4次执行
-
第1次任务的第4次执行
-
第4次任务的第1次执行
-
第4次任务的第2次执行
-
第4次任务的第3次执行
-
第4次任务的第4次执行
上段代码中,创建了一个固定大小的线程池,容量为3,然后循环执行了4个任务,由输出结果可以看到,前3个任务首先执行完,然后空闲下来的线程去执行第4个任务,在FixedThreadPool中,有一个固定大小的池,如果当前需要执行的任务超过了池大小,那么多于的任务等待状态,直到有空闲下来的线程执行任务,而当执行的任务小于池大小,空闲的线程也不会去销毁。 2. CachedThreadPool
上段代码其它地方不变,将newFixedThreadPool方法换成newCachedThreadPool方法。
输出结果:
-
第3次任务的第1次执行
-
第4次任务的第1次执行
-
第1次任务的第1次执行
-
第2次任务的第1次执行
-
第4次任务的第2次执行
-
第3次任务的第2次执行
-
第2次任务的第2次执行
-
第1次任务的第2次执行
-
第2次任务的第3次执行
-
第3次任务的第3次执行
-
第1次任务的第3次执行
-
第4次任务的第3次执行
-
第2次任务的第4次执行
-
第4次任务的第4次执行
-
第3次任务的第4次执行
-
第1次任务的第4次执行
可见,4个任务是交替执行的,CachedThreadPool会创建一个缓存区,将初始化的线程缓存起来,如果线程有可用的,就使用之前创建好的线程,如果没有可用的,就新创建线程,终止并且从缓存中移除已有60秒未被使用的线程。
3. SingleThreadExecutor
上段代码其它地方不变,将newFixedThreadPool方法换成newSingleThreadExecutor方法。
输出结果:
-
第1次任务的第1次执行
-
第1次任务的第2次执行
-
第1次任务的第3次执行
-
第1次任务的第4次执行
-
第2次任务的第1次执行
-
第2次任务的第2次执行
-
第2次任务的第3次执行
-
第2次任务的第4次执行
-
第3次任务的第1次执行
-
第3次任务的第2次执行
-
第3次任务的第3次执行
-
第3次任务的第4次执行
-
第4次任务的第1次执行
-
第4次任务的第2次执行
-
第4次任务的第3次执行
-
第4次任务的第4次执行
4个任务是顺序执行的,SingleThreadExecutor得到的是一个单个的线程,这个线程会保证你的任务执行完成,如果当前线程意外终止,会创建一个新线程继续执行任务,这和我们直接创建线程不同,也和newFixedThreadPool(1)不同。
4.ScheduledThreadPool
-
importjava.util.concurrent.ScheduledExecutorService;
-
importjava.util.concurrent.TimeUnit;
-
publicclassThreadPoolTest{
-
publicstaticvoidmain(String[]args){
-
ScheduledExecutorServiceschedulePool=Executors.newScheduledThreadPool(1);
-
-
schedulePool.schedule(newRunnable(){
-
publicvoidrun(){
-
System.out.println("爆炸");
-
}
-
},5,TimeUnit.SECONDS);
-
-
schedulePool.scheduleAtFixedRate(newRunnable(){
-
@Override
-
publicvoidrun(){
-
System.out.println("爆炸");
-
}
-
},5,2,TimeUnit.SECONDS);
-
}
-
}
ScheduledThreadPool是一个固定大小的线程池,与FixedThreadPool类似,执行的任务是定时执行。
Java的并发包很强大,上面所说只是入门,随着学习深入,会有更多记录在博客里。
本文来自:高爽|Coder,原文地址:http://blog.csdn.net/ghsau/article/details/7443324。
分享到:
相关推荐
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线程池 #### 一、概述 在深入探讨自定义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,线程任务的提交方式等等。
本文所提及的基于Java线程池技术的数据爬虫设计与实现,不仅涉及到了数据爬虫的原理和架构,还包括了多线程编程的知识点,以及线程池技术在数据爬虫中的具体应用。 首先,数据爬虫的基本原理是模拟用户的点击行为,...