JAVA线程池的使用

一、池化思想和JAVA线程池

池化是很重要的思想;池化的好处是提供缓冲和统一的管理。这个笔者在本人的数据库连接池的博客中已经提到过了(JAVA常用数据库连接池_王者之路001的博客-CSDN博客

)。

线程池是另一种池化思想的运用,把线程放入池中进行管理。这种方法的好处是可以避免线程的创建、切换和销毁,因为这些过程非常耗资源。

JAVA线程池就是这样的一种线程池。

二、JAVA线程池基本原理

JAVA线程池的基本原理,其实就是对线程的生产者-消费者模型。线程池对产生的任务进行序贯执行。

JAVA线程池主要做的事情是对线程池的管理和任务的执行。

JAVA线程池的使用_第1张图片

 如上图所示,右半部分是线程池的管理,而左半部分是任务的执行。

任务执行通过阻塞队列来完成。

线程池执行任务如下图所示:

JAVA线程池的使用_第2张图片

JAVA线程池会确定核心线程数和最大线程数,来控制线程池的大小。

三、JAVA线程池的使用

JAVA线程池主要有newCachedThreadPool、newFixedThreadPool、newSingleThreadExecutor和newScheduledThreadPool。

一般通过父类ExecutorService声明使用。代码样例如下:

public class FixedThreadPool {
    public static void main(String[] args) {
        ExecutorService executorService = Executors.newFixedThreadPool(10);
        for (int i = 0; i < 200; i++) {
            executorService.execute(new Task());
        }
        executorService.shutdown();
    }
}

其中,Task为相关线程。也可以采用匿名函数等方式运行。

四、避免的问题

一般情况下,大厂都不建议工程师自己创建线程池,因为线程池创建很容易消耗大量内存。大厂一般有自己的线程池创建模型。

参考文献

[1]Java线程池实现原理及其在美团业务中的实践 - 美团技术团队

[2]面试必问:Java 线程池 | Java程序员进阶之路

[3]JUC线程池: ThreadPoolExecutor详解 | Java 全栈知识体系

[4]https://www.cnblogs.com/vipstone/p/14149065.html

[5]彻底搞懂Java线程池的工作原理-51CTO.COM

[6]https://www.cnblogs.com/pcheng/p/13540619.html

你可能感兴趣的:(JAVA,并发,java,线程池)