定时器+线程池

Posted 无赖H4

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了定时器+线程池相关的知识,希望对你有一定的参考价值。

定时器+线程池

定时器

定时器:定时器就像设置一个闹钟,当时间到达后完成某件事情,像JS中的是setTimeout。
(JS中的setInterval是每隔多久执行一次)

1、我们使用定时器的时候,最主要的是小一个任务Runnable,TimeTask就实现了Runnable接口,所以我们直接创建一个Task。
2、设置定时器:Timer timer = new Timer();

3、调度:利用timer.schedule()方法设置task和delay;
schedule方法:
在这里插入图片描述
例如:会在5秒后打印:hello

public class Demo {
    public static void main(String[] args) {
        TimerTask task = new TimerTask() {
            @Override
            public void run() {
                System.out.println("hello");
            }
        };

        Timer timer = new Timer();
        timer.schedule(task,5000);
    }
}

scheduleAtFixedRate是周期性执行任务
例如:timer.scheduleAtFixedRate(task,1000,2000);就是1秒后执行task,然后每隔2秒执行一次。

线程池

为什么需要线程池呢?
如果每次来任务都创建一个新的线程,那么会造成很大的损失。
如果可以将创建的线程放进线程池,下一次如果还需要这个线程,就可以直接使用。
线程池的最大好处就是减少每次启动销毁的损耗

创建

在这里插入图片描述
构造方法:
在这里插入图片描述
在这里插入图片描述
拒绝策略:
在这里插入图片描述

Executors

工厂类Executors,可以将new的步骤省略
在这里插入图片描述

Executors.newFixedThreadPool(3);
//就是new一个固定大小的线程池

Executors.newCachedThreadPool();
//创建临时的

例如:利用线程池计算斐波那契数:

package threadpool;

import java.util.Scanner;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Demo {
    public static void main(String[] args) {
        ExecutorService pool = Executors.newFixedThreadPool(3);
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入:");
        while (sc.hasNextInt()) {
            int n = sc.nextInt();
            Runnable runnable = new Runnable() {
                @Override
                public void run() {
                    long r = fib(n);
                    System.out.printf("fib(%d) = %d\\n", n, r);
                }
            };

            pool.execute(runnable);
            System.out.println("请输入:");
        }
    }


    private static int fib(int n) {
        if (n < 2) {
            return n;
        }
        return fib(n - 1) + fib(n - 2);
    }
}

以上是关于定时器+线程池的主要内容,如果未能解决你的问题,请参考以下文章

29多线程(线程池定时器)将一个文件复制多次拆分文件并合并多线程复制文件

win10 uwp 线程池

ScheduledThreadExecutor定时任务线程池

大数据进阶26-Lock死锁线程间通信线程组线程池,以及定时器

线程Queue定时器进程池和线程池同步异步

ScheduledThreadPoolExecutor定时任务执行线程池分析