Java 并发-newFixedThreadPool

前言

为什么选择使用多线程?一种场景是在数据和业务处理能力出现瓶颈时,而服务器性能又有空闲,通常是cpu空闲,这时使用多线程就能很好的解决问题,而又无需加硬件,实际使用中,线程池又是最为常用的一种,本文介绍了newFixedThreadPool的使用方法

原理

newFixedThreadPool内部有一种阻塞队列,是一个无界的LinkedBlockingQueue,任务放在队列中,线程由线程池初始化创建好,如果有空闲线程,那么就调用去处理队列中的任务,没有就排队

需要注意的是这个队列可能会变得很大,要注意线程池的处理能力,避免排队任务太多造成内存溢出,其最大值是Integer的上限,不过由于是链表,也可以无限延长,或者可以在参数中显式创建有界阻塞队列,避免这个问题

实际使用

java 复制代码
ExecutorService executor = Executors.newFixedThreadPool(num);

创建线程池,这里num是线程数量

然后这里做了一个循环模拟运行线程,注意最后要关闭线程池

java 复制代码
  for (int i = 0; i < 10; i++) {
            executorService.execute(new Task(i));
        }
        executorService.shutdown();
        
 class Task implements Runnable {
    private int id;
 
    public Task(int id) {
        this.id = id;
    }
 
    public void run() {
        System.out.println("Task " + id + " is running...");
    }       

这种方法是execute方式,也可以使用submit方式,这两种方式区别在于

1,可以用Future对象获取submit的结果

2,execute()方法只能接受Runnable类型的任务,而submit()方法既可以接受Runnable类型的任务,也可以接受Callable类型的任务。

3,execute()方法是一种异步提交方式,即提交任务后立即返回,不会等待任务执行完成。而submit()方法是一种同步提交方式,即提交任务后会阻塞当前线程,直到任务执行完成。

4,而execute()方法没有提供取消任务的方法,submit()方法返回的Future对象可以用来取消任务

5,execute()方法中如果任务执行过程中发生了异常,则异常会被传递到任务提交的地方,并由任务提交的线程来处理。而submit()方法中,如果任务执行过程中发生了异常,异常将被封装在Future对象中,直到调用Future.get()方法时才会将异常抛出

优缺点

NFTP线程池优点在于使用简单,不需要手动的创建,管理,调度线程;同时由于线程数固定,不会出现超出导致系统崩溃,作为一个多线程的实现可以有效处理并发

缺点在于线程数固定,无法动态调整,同时暂存任务的阻塞队列长度无限拓展可能会造成内存耗尽,同时也无法控制任务时长,可能造成后续任务等待时间超长乃至失败,在笔者实际使用时,还发现这个线程池如果重复创建,可能会造成耗尽cpu资源,因为没有任务时长的控制,线程池执行过慢导致阻塞,这时即时手动interrupt依然会堆积线程,导致cpu执行过久无响应

相关推荐
迈火12 小时前
PuLID_ComfyUI:ComfyUI中的图像生成强化插件
开发语言·人工智能·python·深度学习·计算机视觉·stable diffusion·语音识别
wzg201612 小时前
vscode 配置使用pyqt5
开发语言·数据库·qt
老朋友此林13 小时前
MongoDB GEO 项目场景 ms-scope 实战
java·数据库·spring boot·mongodb
板鸭〈小号〉14 小时前
Socket网络编程(1)——Echo Server
开发语言·网络·php
明天会有多晴朗14 小时前
C语言入门教程(第1讲):最通俗的C语言常见概念详解与实战讲解
c语言·开发语言·c++
爱上妖精的尾巴14 小时前
5-20 WPS JS宏 every与some数组的[与或]迭代(数组的逻辑判断)
开发语言·前端·javascript·wps·js宏·jsa
gopher951114 小时前
Go 语言的 panic 和 recover
开发语言·golang
豆沙沙包?15 小时前
2025年--Lc165--H637.二叉树的层平均值(二叉树的层序遍历)--Java版
java·开发语言
迎風吹頭髮15 小时前
UNIX下C语言编程与实践40-UNIX 全局跳转:setjmp 与 longjmp 函数的使用与注意事项
java·c语言·unix
春风霓裳15 小时前
maven-setting配置
java·maven