java ScheduledExecutorService 线程池定时延迟执行

创建工具类
package com.car.framework.config;

import com.car.common.utils.Threads;
import org.apache.commons.lang3.concurrent.BasicThreadFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.ThreadPoolExecutor;

/**
 * 线程池配置
 *
 **/
@Configuration
public class ThreadPoolConfig {
    // 核心线程池大小
    private final int corePoolSize = 50;

    // 最大可创建的线程数
    private final int maxPoolSize = 200;

    // 队列最大长度
    private final int queueCapacity = 1000;

    // 线程池维护线程所允许的空闲时间
    private final int keepAliveSeconds = 300;

    @Bean(name = "threadPoolTaskExecutor")
    public ThreadPoolTaskExecutor threadPoolTaskExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setMaxPoolSize(maxPoolSize);
        executor.setCorePoolSize(corePoolSize);
        executor.setQueueCapacity(queueCapacity);
        executor.setKeepAliveSeconds(keepAliveSeconds);
        // 线程池对拒绝任务(无线程可用)的处理策略
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        return executor;
    }

    /**
     * 执行周期性或定时任务
     */
    @Bean(name = "scheduledExecutorService")
    protected ScheduledExecutorService scheduledExecutorService() {
        return new ScheduledThreadPoolExecutor(corePoolSize,
                new BasicThreadFactory.Builder().namingPattern("schedule-pool-%d").daemon(true).build(),
                new ThreadPoolExecutor.CallerRunsPolicy()) {
            @Override
            protected void afterExecute(Runnable r, Throwable t) {
                super.afterExecute(r, t);
                Threads.printException(r, t);
            }
        };
    }
}

调用方式
    private final ScheduledExecutorService executor = SpringUtils.getBean("scheduledExecutorService");

  //10分钟后从抢单的列表中随机拿一个
        Runnable runnable = new Runnable() {
            @Override
            public void run() {
                CarIssuanceWaitVo carIssuanceWaitVo = new CarIssuanceWaitVo();
                carIssuanceWaitVo.setIssuanceId(entity.getIssuanceId());
                List<CarIssuanceWaitVo> issuanceWaitVos = carIssuanceWaitMapper.queryList(carIssuanceWaitVo);
                //随机取条数据抢单成功
                Collections.shuffle(issuanceWaitVos);
                List<CarIssuanceWaitVo> waitVos = issuanceWaitVos.subList(0, 1);
                CarIssuanceFleetVo carIssuanceFleetVo = new CarIssuanceFleetVo();
                carIssuanceFleetVo.setUserId(waitVos.get(0).getUserId());
                carIssuanceFleetVo.setIssuanceId(waitVos.get(0).getIssuanceId());
                carIssuanceFleetService.addCarIssuanceFleet(carIssuanceFleetVo);
//                executor.shutdown();
            }
        };
        QueryWrapper<CarIssuanceWait> waitQueryWrapper = new QueryWrapper<>();
        waitQueryWrapper.eq("issuance_id",entity.getIssuanceId());
        Integer selectCount = this.baseMapper.selectCount(waitQueryWrapper);
        if(selectCount == 0){
            executor.schedule(runnable, 20, TimeUnit.SECONDS);
        }


## 其他定时延迟的方式:


//延迟多长时间后自动执行任务,只执行1次
		schedualedExecutor.schedule(new Runnable() {
			public void run() {
				System.out.println(Thread.currentThread().getName() + ", 3秒后执行定时任务!" + new Date());
			}
		}, 3, TimeUnit.SECONDS);
		
		//延迟多长时间后自动执行任务,接着每隔多长时间调度1次,调度工作会一直进行
		schedualedExecutor.scheduleAtFixedRate(new Runnable() {
			public void run() {
				System.out.println(Thread.currentThread().getName() + ", 1秒后执行定时任务,接着每隔2秒执行1次!" + new Date());
				try {
					Thread.sleep(3000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
		}, 1, 2, TimeUnit.SECONDS);
		
		//延迟多长时间后自动执行任务,待该线程执行任务结束后,在隔多长时间调度1次,调度工作会一直进行
		schedualedExecutor.scheduleWithFixedDelay(new Runnable() {
			public void run() {
				System.out.println(Thread.currentThread().getName() + ", 1秒后执行定时任务,当前一个任务执行完成后,再每隔2秒执行1次!" + new Date());
				try {
					Thread.sleep(3000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
		}, 1, 2, TimeUnit.SECONDS);


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ScheduledExecutorServiceJava中用来执行定时任务的线程池。它是Executor框架的一种实现,可以在指定的延迟之后或者按固定的时间间隔周期性地执行任务。 使用ScheduledExecutorService可以方便地创建一个线程池,其中的线程会自动调度执行任务,而不需要手动创建和管理线程。ScheduledExecutorService中的线程池可以根据需要动态地调整线程的数量,提供了更好的灵活性和效率。 使用ScheduledExecutorService来创建一个线程池可以通过Executors类的静态方法newScheduledThreadPool()来实现,例如: ```java ScheduledExecutorService executor = Executors.newScheduledThreadPool(5); ``` 上述代码创建了一个包含5个线程的ScheduledExecutorService线程池。 然后,可以使用ScheduledExecutorServiceschedule()方法来安排任务的执行schedule()方法有多个重载形式,其中最常用的形式接受一个Runnable对象和一个延迟时间作为参数,例如: ```java executor.schedule(new RunnableTask(), 5, TimeUnit.SECONDS); ``` 上述代码将会在5秒之后执行RunnableTask任务。 除了schedule()方法外,还有scheduleAtFixedRate()和scheduleWithFixedDelay()方法可以用来周期性地执行任务。scheduleAtFixedRate()方法可以在固定的时间间隔内周期性地执行任务,而scheduleWithFixedDelay()方法则是在任务执行完成后在固定的延迟时间后再次执行任务。 总结起来,ScheduledExecutorService线程池提供了一种方便的方式来执行定时任务,可以根据需要动态调整线程数量,更加灵活和高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值