推荐安卓开发神器(里面有各种UI特效和android代码库实例)
- schedule(task,initDelay):安排所提交的Callable或Runnable任务在initDelay指定的时间后执行。
- scheduleAtFixedRate():安排所提交的Runnable任务按指定的间隔重复执行
- scheduleWithFixedDelay():安排所提交的Runnable任务在每次执行完后,等待delay所指定的时间后重复执行。
代码:ScheduleExecutorService的例子
-
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;public class ScheduledExecutorServiceTest
{
public static void main(String[] args) throws InterruptedException,ExecutionException
{
//*1
ScheduledExecutorService service=Executors.newScheduledThreadPool(2);
//*2
Runnable task1=new Runnable()
{
public void run()
{
System.out.println("Taskrepeating.");
}
};
//*3
final ScheduledFuture future1=service.scheduleAtFixedRate(task1,0,1,TimeUnit.SECONDS);
//*4
ScheduledFuture future2=service.schedule(new Callable()
{
public String call()
{
future1.cancel(true);
return "taskcancelled!";
}
},10,TimeUnit.SECONDS);
System.out.println(future2.get());
//*5
service.shutdown();
}
} -
这个例子有两个任务,第一个任务每隔一秒打印一句“Taskrepeating”,第二个任务在5秒钟后取消第一个任务。
*1:初始化一个ScheduledExecutorService对象,这个对象的线程池大小为2。*2:用内函数的方式定义了一个Runnable任务。*3:调用所定义的ScheduledExecutorService对象来执行任务,任务每秒执行一次。能重复执行的任务一定是 Runnable类型。注意我们可以用TimeUnit来制定时间单位,这也是Java5.0里新的特征,5.0以前的记时单位是微秒,现在可精确到奈秒。*4:调用ScheduledExecutorService对象来执行第二个任务,第二个任务所作的就是在5秒钟后取消第一个任务。*5:关闭服务。
相关推荐
定时器小例子,这是一个经较好定时器应用
在上面的示例代码中,我们使用了 Executors.newSingleThreadScheduledExecutor() 方法来创建一个 ScheduledExecutorService 实例。这个方法创建了一个单线程的cheduledExecutorService,用于执行定时任务。 ...
这是一个jar,很秀。自定义的一个Java定时器工具类。主要是结合Spring Boot一起使用,并在Spring Boot启动的时候一起启动运行。
2. 超时处理:在需要设定操作超时的场景,可以使用ScheduledExecutorService来启动一个任务,当该任务在指定时间内未完成时,取消原任务并进行相应的超时处理。 3. 定时推送:如定期向用户发送消息或邮件提醒。 4. ...
这种情况下,我们可以使用ScheduledExecutorService来实现定时任务的执行。 ScheduledExecutorService是基于线程池设计的定时任务类,每个调度任务都会分配到线程池中的一个线程去执行,也就是说,任务是并发执行,...
ScheduledExecutorService使用线程池执行任务,可以更高效地管理资源,并允许更精确的定时控制。例如: ```java import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; ...
首先,Java提供了多种方式来实现延迟执行,例如使用`java.util.Timer`类、`java.util.concurrent.DelayQueue`或者`java.util.concurrent.ScheduledExecutorService`。这里我们将重点讨论`ScheduledExecutorService`...
您可以在工作线程上运行任务(Runnable或Callable),以指定执行计划(如ScheduledExecutorService),并指定执行时间。 介面 ScheduledFuture<?> schedule( Runnable command, int executeTime, long delay,...
本实例将深入探讨如何使用`ScheduledExecutorService`接口来实现这一功能。`ScheduledExecutorService`是Java并发包`java.util.concurrent`中的一个接口,它提供了延迟执行和周期性执行任务的能力。 首先,我们需要...
在处理并发性和任务执行顺序有严格要求的情况下,推荐使用`ScheduledExecutorService`;而对于需要高级调度特性的大型项目,Quartz这样的库可能是更好的选择。在实际开发中,理解这些工具的工作原理和优缺点,有助于...
以下是使用`ScheduledExecutorService`创建定时关机程序的基本步骤: 1. **创建ExecutorService**:首先,我们需要创建一个`ScheduledExecutorService`实例,通常通过`Executors.newSingleThreadScheduledExecutor...
在提供的代码示例中,`BeeperControl` 类展示了如何使用 `ScheduledExecutorService` 来实现定时任务调度。首先,它创建了一个单线程的 `ScheduledExecutorService` 实例,通过 `Executors.newScheduledThreadPool(1...
总结一下,Spring MVC 的核心在于它的灵活性和可扩展性,它允许开发者使用注解进行简洁的配置,同时提供了强大的数据绑定和异常处理机制。通过理解和掌握 Spring MVC 的配置、注解以及实践应用,开发者可以高效地...
在Java中,我们可以使用多种库和工具来创建和管理定时任务,如Java的内置API `java.util.Timer` 和 `java.util.concurrent.ScheduledExecutorService`。这两个类提供了丰富的功能,帮助开发者在特定时间或周期性地...
Java通用任务执行程序,基于java.util.concurrent.ScheduledExecutorService。 Java通用的任务执行器,基于java.util.concurrent.ScheduledExecutorService工具类实现。 Maven: <groupId>...
JAVA 中提供了多种方式来实现定时器,包括使用 Timer 和 TimerTask 类,使用 ScheduledExecutorService 等。 在 JAVA 中,Timer 和 TimerTask 是两个基本的类,用于实现定时器。Timer 类用于创建一个新的定时器,而...
2. **定时任务实现**:在`contextInitialized`方法中,我们可以启动一个定时任务,例如使用Java的`ScheduledExecutorService`或者Spring的`@Scheduled`注解。`ScheduledExecutorService`是Java并发库的一部分,可以...
这通常涉及到定时任务,比如使用`java.util.Timer`或`java.concurrent.ScheduledExecutorService`来周期性地调用上述方法获取CPU使用率。获取到的数据可以存储在一个缓存结构(如`ConcurrentHashMap`)中,以便后续...
作者在实现定时任务时,使用了 Jdk5 的 Concurrent 包里的 ScheduledExecutorService,来执行简单的循环任务。作者还提到可以使用 Quartz 来实现更复杂的任务调度。 6. 讨论和总结 本文总结了作者对 Memcached 的...
- **资源管理**:`ScheduledExecutorService` 使用 `ThreadPool` 管理线程,可以更好地控制并发和资源消耗。 ### 4. 实际应用 在实际项目中,`ScheduledExecutorService` 更为推荐,因为它提供了更多的控制和更好...