多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
`@EnableScheduling` 是 Spring Boot 中用来开启定时任务的注解。它可以被用于任何标注了 `@Component` 或 `@Configuration` 注解的类中,表示该类中定义的 `@Scheduled` 注解的方法将会被自动注册为一个调度任务。 在使用 `@EnableScheduling` 注解之前,需要确认以下几点: 1. 依赖项:Spring Boot 应用程序中必须包含 `spring-boot-starter-web` 或 `spring-boot-starter` 依赖项。 2. 内部执行器线程池:Spring Boot 会创建一个内部执行器线程池,用于调度定时任务,并且这个线程池基于 `TaskExecutor` 接口。默认情况下,这个线程池会启动一个单独的线程,但是你也可以通过 `ThreadPoolTaskExecutor` 类进行自定义配置。 3. 执行方法的线程安全性:被 `@Scheduled` 注解的方法必须是线程安全的,因为它们可能在多个线程中执行。 下面是一个使用 `@EnableScheduling` 和 `@Scheduled` 注解的例子: ```java import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component @EnableScheduling public class MyScheduler { @Scheduled(fixedDelay = 5000) public void printMessage() { System.out.println("Hello, World!"); } } ``` 在这个例子中,我们创建了一个名为 `MyScheduler` 的组件,并在其类上添加了 `@Component` 注解。同时,我们还在 `MyScheduler` 类上添加了 `@EnableScheduling` 注解,表示该类中的 `@Scheduled` 注解的方法都是调度任务。 接着,我们定义了一个名为 `printMessage` 的方法,并在其上添加了 `@Scheduled` 注解。该注解代表每 5 秒钟执行一次这个方法,并打印一条 “Hello, World!” 的信息。这个方法就是一个定时任务。