设置线程池参数,创建线程池
- corePoolSize要保留在池中的线程数,即使它们是空闲的,除非{@code - allowCoreThreadTimeOut}被设置
- maximumPoolSize允许在池中的最大线程数
- keepAliveTime当线程数大于核心时,这是多余的空闲线程将在终止前等待新任务的最大时间
- unit {@code keepAliveTime}参数的时间单位
- workQueue用于在执行之前保存任务的队列。这个队列将只保存由{@code execute}方法提交的{@code Runnable}任务
- threadFactory是执行器创建新线程时使用的工厂
- handler是执行被阻塞时使用的处理程序,因为线程边界和队列容量达到了
public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler)
private static int corePoolSize = 50;//初始大小
private static int maximumPoolSize = 200; //最大值
//使用线程池管理
private static ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNamePrefix("RiskSafeguard-pool-%d").build();
private static ExecutorService pool = new ThreadPoolExecutor(corePoolSize, maximumPoolSize,
0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
excel导入
/**
* 不动产抵押导入
* @param fil