首页 > 其他分享 >线程池 解析用定制线程池

线程池 解析用定制线程池

时间:2023-07-17 09:46:58浏览次数:72  
标签:ScheduledThreadPoolExecutor static 线程 new 定制 解析 public POOL

/**
 * @author keming.chen
 * @date 2021/6/17 17:12
 * @desc 解析用定制线程池
 **/
public class ParseThreadPools {

    /**
     * 默认使用线程数 = cpu核数*2
     */
    public static final int MAX_THREADS = Runtime.getRuntime().availableProcessors();

    public static final int DOCUMENT_CORE_POOL_SIZE = 3;

    public static final ThreadPoolExecutor DOCUMENT_THREAD_POOL = new ThreadPoolExecutor(DOCUMENT_CORE_POOL_SIZE,
            DOCUMENT_CORE_POOL_SIZE,
            30,
            TimeUnit.SECONDS,
            new LinkedBlockingQueue<>(),
            new ParseThreadFactory("document"));

    public static final ThreadPoolExecutor PARSE_THREAD_POOL = new ThreadPoolExecutor(
            MAX_THREADS,
            3 * MAX_THREADS,
            30,
            TimeUnit.SECONDS,
            new LinkedBlockingQueue<>(),
            new ParseThreadFactory("ocr-marking"));

    public static final ScheduledThreadPoolExecutor SCHEDULE_POOL = new ScheduledThreadPoolExecutor(1, new ParseThreadFactory("news-report"));

    public static final ScheduledThreadPoolExecutor SCHEDULE_ANNOUNCE_POOL = new ScheduledThreadPoolExecutor(1, new ParseThreadFactory("parse-announce"));

    public static final ScheduledThreadPoolExecutor SCHEDULE_REPEAT_POOL = new ScheduledThreadPoolExecutor(1, new ParseThreadFactory("data-repeat"));

    public static final ScheduledThreadPoolExecutor SCHEDULE_ELECTION_POOL = new ScheduledThreadPoolExecutor(1, new ParseThreadFactory("election"));

}

文档解析的时候,我们会指定3个核心线程,最大线程也是3,阻塞队列是 LinkedBlockingQueue 

 

 

 

如果不指定线程工厂时,ThreadPoolExecutor 会使用ThreadPoolExecutor.defaultThreadFactory 创建线程。默认工厂创建的线程:同属于相同的线程组,具有同为 Thread.NORM_PRIORITY 的优先级,以及名为 “pool-XXX-thread-” 的线程名(XXX为创建线程时顺序序号),且创建的线程都是非守护进程。

标签:ScheduledThreadPoolExecutor,static,线程,new,定制,解析,public,POOL
From: https://www.cnblogs.com/ZhangZiXue/p/17559127.html

相关文章

  • 线程启动、结束,创建线程多法、join,detach
    线程启动、结束,创建线程多法、join,detach视频链接:https://www.bilibili.com/video/BV1Yb411L7ak/?p=4&spm_id_from=333.880.my_history.page.click&vd_source=4c026d3f6b5fac18846e94bc649fd7d0参考博主文章:https://blog.csdn.net/qq_38231713/article/details/106091372join......
  • 常用语言的线程模型(Java、go、C++、python3)
    背景知识软件是如何驱动硬件的?硬件是需要相关的驱动程序才能执行,而驱动程序是安装在操作系统内核中。如果写了一个程序A,A程序想操作硬件工作,首先需要进行系统调用,由内核去找对应的驱动程序驱使硬件工作。而驱动程序怎么让硬件工作的呢?驱动程序作为硬件和操作系统之间的媒介,可以......
  • 使用Java线程同步工具类CountDownLatch
    java.util.concurrent.CountDownLatch是Java并发并发编程中的线程同步工具类,基于AQS(java.util.concurrent.locks.AbstractQueuedSynchronizer)实现。CountDownLatch工具类主要应用在如下场景:等待一组线程执行完毕后继续执行后续操作。应用举例:模拟使用多个线程同时调用多个RPC方......
  • 使用Java线程同步工具类CyclicBarrier
    如何使用java.util.concurrent.CyclicBarrier是Java并发并发编程中的线程同步工具类,基于java.util.concurrent.locks.ReentrantLock实现。CyclicBarrier工具类主要应用在如下场景:让一组线程同时到达栅栏位置才能开始执行。应用示例:publicstaticvoidmain(String[]args){......
  • 【线程池添加工作线程的流程】
    线程池添加工作线程:首先,线程池需要有一个存储工作线程的容器,比如可以使用一个List或者Queue。然后,使用一个变量来保存当前线程池中的线程数。在添加工作线程之前,需要进行两个判断。第一个判断是当前线程池中的线程数是否超过了最大线程数。如果超过了最大线程数,那么直接返......
  • ThreadPoolTaskExecutor自定义线程池的配置和使用
    ThreadPoolTaskExecutor自定义线程池的配置和使用线程池ThreadPoolTaskExecutor和ThreadPoolExecutor的区别ThreadPoolExecutor,这个类是JDK中的线程池类,继承自Executor,里面有一个execute()方法,用来执行线程,线程池主要提供一个线程队列,队列中保存着所有等待状态的线程,避免了创......
  • 什么是进程和线程? 为什么要引入线程? 进程和线程的区别?
    什么是进程和线程?为什么要引入线程?进程和线程的区别? 什么是进程和线程?什么是进程?进程是程序在某个数据集合上的一次运行活动(不仅包含正在运行的程序实体,并且包括这个运行的程序中占据的所有系统资源,比如说CPU、内存、网络资源等),也是操作系统进行资源分配和保护的基......
  • spring boot 接口多线程
    SpringBoot接口多线程在单线程的环境中,当接口请求过多时,容易造成阻塞和性能问题。为了提高系统的响应速度和吞吐量,我们可以使用多线程来处理接口请求。本文将介绍如何在SpringBoot中使用多线程处理接口请求,并给出相应的代码示例。什么是多线程多线程是指在一个进程中同时执行......
  • Java-多线程-八股文
    线程安全的理解?线程安全说的是,当多个线程并发访问互斥资源时,读写互斥资源的代码逻辑能正常处理,获得正确结果,不会互相干扰的情况。守护线程的理解?守护线程是与普通线程相区分的概念,用户一般使用的就是普通线程,普通线程有自身独立的生命周期,而守护线程的生命周期取决于普通......
  • Python的多线程(threading)与多进程(multiprocessing )
    可以用来做后台任务,可以在djangoview中调用,当做异步任务考核系统中要的threading,用来异步考核结果和考核进度的统计Python的多线程(threading)与多进程(multiprocessing)......