跳转到帖子

游客您好,欢迎来到黑客世界论坛!您可以在这里进行注册。

赤队小组-代号1949(原CHT攻防小组)在这个瞬息万变的网络时代,我们保持初心,创造最好的社区来共同交流网络技术。您可以在论坛获取黑客攻防技巧与知识,您也可以加入我们的Telegram交流群 共同实时探讨交流。论坛禁止各种广告,请注册用户查看我们的使用与隐私策略,谢谢您的配合。小组成员可以获取论坛隐藏内容!

TheHackerWorld官方

精选回复

发布于
public static void main(String[] args) {
        //同时执行3个
        execute(1,8);
        execute(2,15);
        execute(3,20);
        execute(4,30);

    }
    public static void execute(Integer startTime,Integer endTime){
        // 创建一个ScheduledThreadPoolExecutor线程池,核心线程数为8
        ScheduledExecutorService scheduledExecutorService = new ScheduledThreadPoolExecutor(8);
        //开始
        scheduledExecutorService.schedule(new Runnable() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"开始执行了.....");
            }
        }, startTime, TimeUnit.SECONDS);//单位秒
        //结束 
        scheduledExecutorService.schedule(new Runnable() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行结束了......");
            }
        }, endTime, TimeUnit.SECONDS);//单位秒
    }

总结:ScheduledExecutorService是基于线程池设计的定时任务类,在java的JUC包中,它的每个调度任务都会分配到线程池中的一个线程去执行,并发不受影响,各自执行各自的。

它有三个方法:

  1. schedule:只执行一次调度
  2. scheduleAtFixedRate:一开始就计算间隔时间,如果任务超过间隔时间,那么就直接开始下一个任务
  3. scheduleWithFixedDelay:任务无论执行多久,都要等待上一轮任务完成之后再间隔指定时间,然后才开始下一个任务

这里我们只演示了第一个方法,其他方法用法差不多。

创建帐户或登录后发表意见

最近浏览 0

  • 没有会员查看此页面。