`
zhoujiangzi
  • 浏览: 92768 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

java 线程池

阅读更多

在jdk1.5里面已经为我们添加了线程池这个特性,因此我们在使用过程中还是比较方便的。

通过工具类java.util.concurrent.Executors可以轻松的创建线程池,通过查看源码,发现创建线程池的方法比较多,可以创建固定大小,带缓存和定时任务。这里主要看下固定大小和定时任务的线程池

1.固定大小线程池:

首先创建3个线程池,通过工具类Executors来完成,具体如下

 

ExecutorService threadPools = Executors.newFixedThreadPool(3);

 这样就创建了线程池,这里为了简单操作,采用execute来执行线程操作而不是通过submit,当然submit提交后返回Future能更方便的了解线程执行的结果

 

 

package com.jacksoft.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;


/**
 *  线程池
 * @author Jack
 *
 */
public class ThreadPoolTest {

	public static void main(String[] args) {
		
		ExecutorService threadPools = Executors.newFixedThreadPool(3);
		
		for(int i = 0; i < 3; i++){
			threadPools.execute(new Runnable() {
				@Override
				public void run() {
					System.out.println(Thread.currentThread().getName() + "运行");
				}
			});
		}
		threadPools.shutdown();
	}
}

 首先我们创建的是3个大小的线程池,然后再通过循环,分别执行execute方法来实现线程运行

 

2.定时任务线程

有时候我们需要创建一个线程,但是不是立刻就执行或者说规定的什么时候才去执行,这时就需要一个定时线程来完成,对应线程池同样采用Executors工具来创建

 

ScheduledExecutorService  threadPools = Executors.newScheduledThreadPool(2);

 返回java.util.concurrent.ScheduledExecutorService的实现,该接口继承ExecutorService,所以还是可以通过execute方法来执行线程,但是这样就不能实现定时的作用。这里需要调用schedule方法来完成调度,跟定时器实现一样,查看ScheduledExecutorService.schedule方法

 

 

  /**
     * Creates and executes a one-shot action that becomes enabled
     * after the given delay.
     *
     * @param command the task to execute
     * @param delay the time from now to delay execution
     * @param unit the time unit of the delay parameter
     * @return a ScheduledFuture representing pending completion of
     *         the task and whose <tt>get()</tt> method will return
     *         <tt>null</tt> upon completion
     * @throws RejectedExecutionException if the task cannot be
     *         scheduled for execution
     * @throws NullPointerException if command is null
     */
    public ScheduledFuture<?> schedule(Runnable command,
				       long delay, TimeUnit unit);

 

 

需要传递3个参数,第一个Runnable实现,这个很熟悉了,delay是从现在开始多久执行,unit是delay的时间单位,可以通过TimeUnit来获取

下面就写个简单的运行后2秒再开始执行线程

 

package com.jacksoft.thread;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;


/**
 *  线程池
 * @author Jack
 *
 */
public class ThreadPoolTest {

	public static void main(String[] args) {
		
		ScheduledExecutorService  threadPools = Executors.newScheduledThreadPool(2);
		
		for(int i = 0; i < 2;i++){
			threadPools.schedule(new Runnable() {
				@Override
				public void run() {
						System.out.println(Thread.currentThread().getName() + "定时器执行");
				}
			}, 2, TimeUnit.SECONDS);
		}

		threadPools.shutdown();
	}
}

 这样再2秒之后,才会执行线程。

 

和定时器一样,也可以一直运行,可以分别通过scheduleWithFixedDelay和scheduleAtFixedRate方法来完成调度,我们先采用scheduleWithFixedDelay方法来完成

package com.jacksoft.thread;

import java.util.Calendar;
import java.util.Date;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;


/**
 *  线程池
 * @author Jack
 *
 */
public class ThreadPoolTest {

	public static void main(String[] args) {
		
		ScheduledExecutorService  threadPools = Executors.newScheduledThreadPool(2);
		
		for(int i = 0; i < 2;i++){
			threadPools.scheduleWithFixedDelay(new Runnable() {
				@Override
				public void run() {
					try {
						Thread.sleep(5000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					System.out.println(Thread.currentThread().getName() + "运行" + new Date().getSeconds());
				}
			},0, 4, TimeUnit.SECONDS);
		}
	}
}

 这里采用sleep来模拟业务处理过程,让该线程睡眠5秒,程序运行的结果如下:

pool-1-thread-2运行53
pool-1-thread-1运行53
pool-1-thread-1运行2
pool-1-thread-2运行2
pool-1-thread-1运行11
pool-1-thread-2运行11
pool-1-thread-1运行20
pool-1-thread-2运行20

再来通过scheduleAtFixedRate来完成调度,同样的打印执行结果,代码如下:

package com.jacksoft.thread;

import java.util.Calendar;
import java.util.Date;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

/**
 * 线程池
 * 
 * @author Jack
 * 
 */
public class ThreadPoolTest {

	public static void main(String[] args) {

		ScheduledExecutorService threadPools = Executors
				.newScheduledThreadPool(2);

		for (int i = 0; i < 2; i++) {
			threadPools.scheduleAtFixedRate(new Runnable() {
				@Override
				public void run() {
					try {
						Thread.sleep(5000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					System.out.println(Thread.currentThread().getName() + "运行"
							+ new Date().getSeconds());
				}
			}, 0, 4, TimeUnit.SECONDS);
		}
	}
}

 执行结果:

pool-1-thread-2运行29
pool-1-thread-1运行29
pool-1-thread-1运行34
pool-1-thread-2运行34
pool-1-thread-1运行39
pool-1-thread-2运行39
pool-1-thread-1运行44
pool-1-thread-2运行44

 

通过上面两个方法都可以实现定时调度我们的任务,但是通过打印结果来看,还是存在区别的

scheduleAtFixedRate 这个方法是不管你有没有执行完,反正我每隔4秒来执行一次,以相同的频率来执行

scheduleWithFixedDelay 这个是等你方法执行完后,我再隔4秒来执行,也就是相对延迟后,以固定的频率去执行

举个列子:

1. 当我们去坐火车时,火车都准点发车,当然在这种情况很少,除非始发站微笑。那么火车是不会等你的,到点了他就运行,然后隔一天,同样的车次在同样的时间又开始运行,他不管前一天的火车是不是已经到达终点,这就是scheduleAtFixedRate 调度

2. 日常生活中一日三餐,早饭吃完了,休息或者上班到中午,再吃午饭,然后又是上班到晚上再吃晚饭,不能早饭一直吃到中午,然后马上又吃午饭吧,等一件事件做完了,然后相对间隔多久,再去做这件事情,这就是scheduleWithFixedDelay 调度,可能这个例子不是很好。。。

 

分享到:
评论

相关推荐

    java线程池使用后到底要关闭吗

    java线程池使用后到底要关闭吗 java线程池是一种高效的并发编程技术,可以帮助开发者更好地管理线程资源,提高系统的性能和可靠性。然而,在使用java线程池时,一个常见的问题是:使用完线程池后到底要不要关闭?...

    java线程池完整代码

    "Java 线程池完整代码解析" Java 线程池是 Java 语言中的一个重要概念,它允许开发者创建和管理多个线程,以提高程序的并发性和性能。下面是对给定文件的解析,包括 title、description、标签和部分内容的解析。 ...

    java线程池封装j

    Java线程池是一种高效管理线程的技术,它允许开发者预定义一组线程,根据任务的需要灵活调度,而不是每次需要执行任务时都创建新的线程。这种设计模式大大提高了系统的性能,减少了系统资源的消耗,特别是在高并发...

    java线程池实例详细讲解

    Java线程池是一种高效管理线程资源的工具,它能够帮助开发者有效地控制并调度线程,从而提升系统性能,减少系统资源的浪费。在Java中,`ExecutorService`接口是线程池的主要入口,它是`java.util.concurrent`包的一...

    java线程池知识.ppt

    java线程池知识、

    Java线程池使用说明

    Java线程池是Java并发编程中的重要组件,它能够有效地管理和复用线程,从而提高程序的执行效率和降低资源消耗。在JDK 1.5版本之前,Java对线程池的支持非常有限,而在JDK 1.5之后,加入了java.util.concurrent包,...

    自定义实现Java线程池

    ### 自定义实现Java线程池 #### 一、概述 在深入探讨自定义Java线程池之前,我们先简要回顾一下线程池的基本概念及其重要性。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动...

    java线程池的源码分析.zip

    Java线程池是Java并发编程中的重要组成部分,它在多线程和高并发场景下扮演着关键角色。本文将深入探讨Java线程池的源码分析,并对比不同类型的线程池,以帮助开发者更好地理解和利用这一强大的工具。 首先,我们要...

    Java 线程池.docx

    Java线程池是一种高效管理线程资源的工具,它的出现是为了应对多线程编程中频繁创建和销毁线程带来的性能开销以及资源消耗。在Java中,通过使用线程池,我们可以预先创建一定数量的线程,这些线程在空闲时可以被复用...

    Java线程池与ThreadPoolExecutor.pdf

    Java线程池是Java并发编程中的重要组成部分,它允许开发者管理多个线程并有效地调度任务。线程池通过ThreadPoolExecutor类实现,这是一个高度可配置的工具,能够根据具体需求定制线程的创建、管理和销毁策略。 ...

    Java简单线程池 线程池中文文档

    简单的线程池程序+中文文档 包结构: com.tangkai.threadpool --SimpleThread.java 工作线程 --TestThreadPool.java 程序入口 --ThreadPoolManager.java 线程池管理类

    一个通用的Java线程池类

    2.然后根据提示运行java命令执行示例程序,观看线程池的运行结果 目标:Java中多线程技术是一个难点,但是也是一个核心技术。因为Java本身就是一个多线程语言。本人目前在给46班讲授Swing的网络编程--使用Swing来...

    Java 线程池的原理与实现

    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线程池技术实现Knock Knock游戏项目.zip 基于Java线程池...

    JAVA线程池的原理与实现.pdf

    Java线程池是一种高效利用系统资源、管理并发执行任务的机制。它的原理是通过预先创建一组线程,这些线程在任务到来时可以立即执行,而不是每次需要执行任务时都新建线程,从而降低了线程创建和销毁带来的开销。...

    Java线程池及观察者模式解决多线程意外死亡重启问题

    Java线程池是Java并发编程中的重要组成部分,它允许开发者高效地管理多个并发执行的线程,有效地控制系统的资源消耗,提高系统性能和稳定性。在Java中,`java.util.concurrent`包提供了`ExecutorService`接口及其...

    Java 线程池.pptx

    讲述了java线程池的优点,参数,6种线程池的使用场景,线程池用到的handler,线程任务的提交方式等等。

    基于Java线程池技术的数据爬虫设计与实现.pdf

    本文所提及的基于Java线程池技术的数据爬虫设计与实现,不仅涉及到了数据爬虫的原理和架构,还包括了多线程编程的知识点,以及线程池技术在数据爬虫中的具体应用。 首先,数据爬虫的基本原理是模拟用户的点击行为,...

Global site tag (gtag.js) - Google Analytics