开发者社区> 西北野狼> 正文

java多线程 -- 线程池

简介: 第四种获取线程的方法:线程池,一个 ExecutorService,它使用可能的几个池线程之一执行每个提交的任务,通常使用 Executors 工厂方法配置。 线程池可以解决两个不同问题:由于减少了每个任务调用的开销,它们通常可以在执行大量异步任务时提供增强的性能,并且还可以提供绑定和管理资源(包括执行任务集时使用的线程)的方法。
+关注继续查看

第四种获取线程的方法:线程池,一个 ExecutorService,它使用可能的几个池线程之一执行每个提交的任务,通常使用 Executors 工厂方法配置。

线程池可以解决两个不同问题:由于减少了每个任务调用的开销,它们通常可以在执行大量异步任务时提供增强的性能,并且还可以提供绑定和管理资源(包括执行
任务集时使用的线程)的方法。每个 ThreadPoolExecutor 还维护着一些基本的统计数据,如完成的任务数。

为了便于跨大量上下文使用,此类提供了很多可调整的参数和扩展钩子 (hook)。但是,强烈建议程序员使用较为方便的 Executors 工厂方法 :

  1. Executors.newCachedThreadPool()(无界线程池,可以进行自动线程回收)
  2. Executors.newFixedThreadPool(int)(固定大小线程池)
  3. Executors.newSingleThreadExecutor()(单个后台线程)

它们均为大多数使用场景预定义了设置.

线程池封装类(android开发中用过):

package com.company;

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

/**
 * @类名: ThreadUtils
 * @描述: TODO(线程池工具类)
 * @作者: soyoungboy
 */
public class ThreadUtils {
    private static volatile ThreadUtils instance = null;

    // private constructor suppresses
    private ThreadUtils() {

    }

    public static ThreadUtils getInstance() {
        // if already inited, no need to get lock everytime
        if (instance == null) {
            synchronized (ThreadUtils.class) {
                if (instance == null) {
                    instance = new ThreadUtils();
                }
            }
        }

        return instance;
    }

    /**
     * 初始化的线程数,有待历史的验证,暂时弄4个
     */
    public ExecutorService threadPool = Executors.newFixedThreadPool(4);

    /**
     * 单线程
     */
    static ExecutorService singleThreadPool = Executors.newSingleThreadExecutor();

    /**
     * 执行延迟任务,类似Timer的效果
     */
    public ScheduledExecutorService scheduleThreadPool = Executors.newScheduledThreadPool(2);

    /**
     * 立即执行任务
     *
     * @param task ThreadUtils.getInstance().excute(run);
     */
    public void excute(Runnable task) {
        threadPool.execute(task);
    }

    /**
     * 单线程持操作,主要用于数据库的读写异步操作
     *
     * @param task ThreadUtils.getInstance().excuteSingleThread(run);
     * @return
     */
    public Future excuteSingleThread(Runnable task) {
        return singleThreadPool.submit(task);
    }

    ;

    /**
     * 延后执行任务
     *
     * @param task
     * @param delay ThreadUtils.getInstance().schedule(run,1000);
     */
    public void schedule(Runnable task, long delay) {
        scheduleThreadPool.schedule(task, delay, TimeUnit.MILLISECONDS);
    }


    /**
     * @return void 返回类型
     * @Title: shutdownThreadPool
     * @Description: TODO()
     */
    public void shutdownThreadPool() {
        threadPool.shutdownNow();
    }

    /**
     * @return void 返回类型
     * @Title: shutdownThreadPool
     * @Description: TODO()
     */
    public void shutdownScheduleThreadPool() {
        scheduleThreadPool.shutdownNow();

    }

    /**
     * @return void 返回类型
     * @Title: shutdownSingleThreadPool
     * @Description: TODO(单线程池销毁操作)
     */
    public void shutdownSingleThreadPool() {
        singleThreadPool.shutdownNow();
    }
}

 

Demo:

public class TestScheduledThreadPool {

    public static void main(String[] args) throws Exception {
        ThreadUtils instance = ThreadUtils.getInstance();
        for (int i = 0; i < 10; i++) {
            instance.schedule(() -> {
                int num = new Random().nextInt(100);//生成随机数
                System.out.println(Thread.currentThread().getName() + " : " + num);
            }, 3);
        }
        instance.shutdownScheduleThreadPool();

    }

}

结果:

pool-3-thread-2 : 79
pool-3-thread-1 : 87
pool-3-thread-2 : 44
pool-3-thread-1 : 90
pool-3-thread-2 : 0
pool-3-thread-1 : 77
pool-3-thread-2 : 20
pool-3-thread-1 : 63
pool-3-thread-2 : 68
pool-3-thread-1 : 15

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
面试官:线程池多余的线程是如何回收的?
最近阅读了JDK线程池ThreadPoolExecutor的源码,对线程池执行任务的流程有了大体了解,实际上这个流程也十分通俗易懂,就不再赘述了,别人写的比我好多了。
36 0
多线程基础
需要了解的概念 并发和并行 并发侧重于任务的交替执行,同一时间只能执行一个任务;而并行是任务的同时执行,统一时间可以有多个任务被执行。 单核CPU与多核CPU下任务表现分别为并发与并行。 临界区 临界区用于表示一种公共资源或是共享数据,可以被多个线程使用,但是同一时间内,只能有一个线程在使用它。
738 0
java多线程体系
之前想多写写java多线程相关的东西,于是对java的多线程做了一些总结,最后汇成了一张java多线程相关的体系结构图什么都不说了,先上图吧欢迎大家拍砖
9708 0
java多线程 -- 线程八锁
一个对象里面如果有多个synchronized方法,某一个时刻内,只要一个线程去调用其中的一个synchronized方法了,其它的线程都只能等待,换句话说,某一个时刻内,只能有唯一一个线程去访问这些synchronized方法锁的是当前对象this,被锁定后,其它的线程都不能进入到当前对象的其它的synchronized方法 加个普通方法后发现和同步锁无关 换成两个对象后,不是同一把锁了,情况立刻变化。
830 0
VC多线程编程
一、问题的提出 编写一个耗时的单线程程序:   新建一个基于对话框的应用程序SingleThread,在主对话框IDD_SINGLETHREAD_DIALOG添加一个按钮,ID为IDC_SLEEP_SIX_SECOND,标题为“延时6秒”,添加按钮的响应函数,代码如下:  void CSingleThreadDlg::OnSleepSixSecond() { Sleep(6000); //延时6秒}   编译并运行应用程序,单击“延时6秒”按钮,你就会发现在这6秒期间程序就象“死机”一样,不在响应其它消息。
817 0
Java多线程--线程操作范例
<h1>1、实例要求</h1> <div> <span style="white-space:pre"></span>设计一个线程操作类,要求可以产生三个线程对象,并可以分别设置三个线程的休眠时间:</div> <div> <span style="white-space:pre"></span>线程A : 休眠10秒</div> <div> <span style="white-s
901 0
+关注
西北野狼
擅长Android ,J2EE开发 博客园地址:http://www.cnblogs.com/androidsuperman/p/7834762.html github地址: https://github.com/soyoungboy
463
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载