ThreadPoolExecutor线程池默认阻塞队列的大小
时间: 2023-11-02 20:59:38 浏览: 53
ThreadPoolExecutor线程池的默认阻塞队列大小为Integer.MAX_VALUE,即无界队列。这意味着当任务提交到线程池时,如果线程池的线程数已达到核心线程数(corePoolSize)的上限,而阻塞队列又未满,则任务会被添加到阻塞队列中等待执行。由于队列大小为无限大,所以不会造成任务被拒绝执行。当阻塞队列已满时,才会创建新的线程执行任务。
相关问题
ThreadPoolExecutor线程池有哪些参数?
ThreadPoolExecutor线程池有以下参数:
1. corePoolSize:核心线程数,即线程池中始终保持的线程数,即使它们处于空闲状态也不会被回收。
2. maximumPoolSize:最大线程数,即线程池中允许存在的最大线程数,包括空闲线程和阻塞队列中等待的线程。
3. keepAliveTime:线程空闲时间,即当线程池中的线程数量大于核心线程数时,空闲线程的存活时间。
4. TimeUnit:时间单位,用于指定keepAliveTime参数的时间单位。
5. workQueue:工作队列,用于存放等待执行的任务,可以选择不同类型的队列,如ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue等。
6. ThreadFactory:线程工厂,用于创建线程,默认情况下使用Executors.defaultThreadFactory()方法创建线程。
7. RejectedExecutionHandler:拒绝策略,用于处理无法执行的任务,默认情况下使用AbortPolicy策略,即抛出RejectedExecutionException异常。其他策略还包括DiscardPolicy、DiscardOldestPolicy和CallerRunsPolicy。
ThreadPoolTaskExecutor默认队列
ThreadPoolTaskExecutor默认队列是什么?
回答: ThreadPoolTaskExecutor默认队列是一个阻塞队列,具体实现是BlockingQueue。[1] ThreadPoolTaskExecutor是Spring框架中的线程池技术,它使用threadPoolExecutor进行实现。在ThreadPoolTaskExecutor的代码中,可以看到initializeExecutor方法中创建了一个BlockingQueue来作为默认队列。[3] 这个阻塞队列用于存储等待执行的任务,当线程池中的线程已满时,新的任务会被放入这个队列中等待执行。