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执行过久无响应

相关推荐
默 语6 分钟前
Records、Sealed Classes这些新特性:Java真的变简单了吗?
java·开发语言·python
止观止7 分钟前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
zjshuster15 分钟前
墨西哥中央银行网联清算系统接入总结
java·财务对账
小锋java123416 分钟前
SpringBoot 4 + Spring Security 7 + Vue3 前后端分离项目设计最佳实践
java·vue.js·spring boot
卷心菜狗17 分钟前
Python进阶-深浅拷贝辨析
开发语言·python
一 乐17 分钟前
校园线上招聘|基于springboot + vue校园线上招聘系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园线上招聘系统
时寒的笔记18 分钟前
js逆向7_案例惠nong网
android·开发语言·javascript
不懂的浪漫19 分钟前
mqtt-plus 架构解析(四):MqttMessageInterceptor 的扩展点设计
java·spring boot·物联网·mqtt
西海天际蔚蓝21 分钟前
AI配合写的第一个demo系统页面
java·人工智能
小旭952735 分钟前
Spring Security 实现权限控制(认证 + 授权全流程)
java·后端·spring