
package com.logicbig.example;
import org.springframework.scheduling.concurrent.SimpleAsyncTaskScheduler;
import java.time.Duration;
import java.time.LocalTime;
import java.time.temporal.ChronoUnit;
public class SimpleAsyncTaskSchedulerExample {
public static void main(String[] args) throws InterruptedException {
SimpleAsyncTaskScheduler scheduler = new SimpleAsyncTaskScheduler();
scheduler.scheduleAtFixedRate(
() -> System.out.printf("Thread: %s, Time: %s%n",
Thread.currentThread().getName(),
LocalTime.now())
, Duration.of(1, ChronoUnit.SECONDS));
Thread.sleep(10000);
//Terminating after 10 seconds
scheduler.close();
}
}
Output
Thread: SimpleAsyncTaskScheduler-2, Time: 16:04:45.668219800
Thread: SimpleAsyncTaskScheduler-3, Time: 16:04:46.668389200
Thread: SimpleAsyncTaskScheduler-4, Time: 16:04:47.665468100
Thread: SimpleAsyncTaskScheduler-5, Time: 16:04:48.674775200
Thread: SimpleAsyncTaskScheduler-6, Time: 16:04:49.673371700
Thread: SimpleAsyncTaskScheduler-7, Time: 16:04:50.669166
Thread: SimpleAsyncTaskScheduler-8, Time: 16:04:51.667201800
Thread: SimpleAsyncTaskScheduler-9, Time: 16:04:52.677053600
Thread: SimpleAsyncTaskScheduler-10, Time: 16:04:53.671418100
Thread: SimpleAsyncTaskScheduler-11, Time: 16:04:54.665984700
Thread: SimpleAsyncTaskScheduler-12, Time: 16:04:55.679457700
Original Post