JAVA线程池

每天一篇系列:
强化知识体系,查漏补缺。
欢迎指正,共同学习!

如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。

线程池可以复用线程避免频繁创建和销毁。

public class MyThread extends Thread {
    public String name;

    public MyThread(String name) {
        // TODO Auto-generated constructor stub
        this.name = name;
    }

    @Override
    public void run() {
        // TODO Auto-generated method stub
        System.out.println(Thread.currentThread().getName() + "正在执行...." + name);
    }
}
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ExecutorTest {
    public static final int NUM_THREADS = 10;
    public static List<Thread> threads = Collections
            .synchronizedList(new ArrayList<Thread>());

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        // 创建一个可重用固定线程数的线程池
        ExecutorService pool = Executors.newSingleThreadExecutor();
        // 创建一个可重用固定线程数的线程池
        // ExecutorService pool = Executors.newFixedThreadPool(4);
        // 创建一个可重用固定线程数的线程池
        // ExecutorService pool = Executors.newCachedThreadPool();
        for (int i = 0; i < NUM_THREADS; i++) {
            Thread t = new MyThread(" i am " + i);
            threads.add(t);
        }
        for (int i = 0; i < NUM_THREADS; i++) {
            pool.execute(threads.get(i));
        }
        // 关闭线程池
        pool.shutdown();
    }
}

java提供了四种线程池的实现:

  1. newSingleThreadExecutor
    创建一个单线程的线程池。这个线程池只有一个线程在工作,也就是相当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。
    输出结果:
pool-1-thread-1正在执行.... i am 0
pool-1-thread-1正在执行.... i am 1
pool-1-thread-1正在执行.... i am 2
pool-1-thread-1正在执行.... i am 3
pool-1-thread-1正在执行.... i am 4
pool-1-thread-1正在执行.... i am 5
pool-1-thread-1正在执行.... i am 6
pool-1-thread-1正在执行.... i am 7
pool-1-thread-1正在执行.... i am 8
pool-1-thread-1正在执行.... i am 9

可以看到线程池里面只有线程1,并且excute()执行复用线程1线程来执行新的任务。
只有一个核心线程,确保所有任务都在同一线程中按顺序完成。因此不需要处理线程同步的问题。
2.newFixedThreadPool
创建固定大小的线程池。每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。
输出结果:

pool-1-thread-1正在执行.... i am 0
pool-1-thread-1正在执行.... i am 4
pool-1-thread-1正在执行.... i am 5
pool-1-thread-1正在执行.... i am 6
pool-1-thread-1正在执行.... i am 7
pool-1-thread-1正在执行.... i am 8
pool-1-thread-1正在执行.... i am 9
pool-1-thread-2正在执行.... i am 1
pool-1-thread-3正在执行.... i am 2
pool-1-thread-4正在执行.... i am 3

可以看到,最终线程池里面只有四条线程,执行是无序的,但是线程还是被复用了。
FixThreadPool只有核心线程,并且数量固定的,也不会被回收,所有线程都活动时,因为队列没有限制大小,新任务会等待执行。由于线程不会回收,FixThreadPool会更快地响应外界请求,这也很容易理解。
3. newCachedThreadPool
创建一个可缓存的线程池。如果线程池的大小超过了处理任务所需要的线程,
那么就会回收部分空闲(60秒不执行任务)的线程,当任务数增加时,此线程池又可以智能的添加新线程来处理任务。此线程池不会对线程池大小做限制,线程池大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。CachedThreadPool是有线程超时机制的,它的超时时间为60秒
输出结果:

pool-1-thread-1正在执行.... i am 0
pool-1-thread-2正在执行.... i am 1
pool-1-thread-3正在执行.... i am 2
pool-1-thread-5正在执行.... i am 4
pool-1-thread-6正在执行.... i am 5
pool-1-thread-7正在执行.... i am 6
pool-1-thread-9正在执行.... i am 8
pool-1-thread-8正在执行.... i am 7
pool-1-thread-10正在执行.... i am 9
pool-1-thread-4正在执行.... i am 3

可以看到线程池里面一共有10条线程,执行是无序的。
CachedThreadPool只有非核心线程,最大线程数非常大,所有线程都活动时,会为新任务创建新线程,否则利用空闲线程(60s空闲时间,过了就会被回收,所以线程池中有0个线程的可能)处理任务。比较适合执行大量的耗时较少的任务,这样才能达到线程被复用的效果,最大程度上减少创建和销毁线程的情况。
4.newScheduledThreadPool
创建一个大小无限的线程池。此线程池支持定时以及周期性执行任务的需求。可以理解为能够定时的newCachedThreadPool。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 线程池是什么? 线程池用于多线程处理中,它可以根据系统的情况,可以有效控制线程执行的数量,优化运行效果。线程池做的...
    懒癌正患者阅读 2,734评论 2 80
  • 更多 Java 并发编程方面的文章,请参见文集《Java 并发编程》 线程组 Thread Group 线程的集合...
    专职跑龙套阅读 1,356评论 0 3
  • 有时候想想挺无奈的,所以总说我不要做没有成就感的事。今儿家教,虽然我的确可以混混就拿到应有的💰,可如果这样我实在有...
    点点DDD阅读 286评论 0 1
  • [多安家学经汇报] 学经时间:2017年2月17日 星期五 正月二十一 晴好,有风 学经人员:多妈、多多(六年级...
    多安妈阅读 171评论 0 0
  • 一、简介 SAML:Security Assertion Markup Language安全断言标记语言标识化组织...
    Hu0buIk阅读 1,416评论 0 1