欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java中Timer定時器的使用和啟動方式

 更新時間:2021年12月28日 11:34:30   作者:iteen  
這篇文章主要介紹了java中Timer定時器的使用和啟動方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Timer定時器的使用和啟動

1.概述

定時計劃任務(wù)功能在Java中主要使用的就是Timer對象,它在內(nèi)部使用多線程的方式進行處理,所以它和多線程技術(shù)還是有非常大的關(guān)聯(lián)的。在JDK中Timer類主要負責(zé)計劃任務(wù)的功能,也就是在指定的時間開始執(zhí)行某一個任務(wù),但封裝任務(wù)的類卻是TimerTask類。

2.應(yīng)用場景

我們使用timer的時候,一般有4種情況:

  • 指定時間執(zhí)行
  • 指定時間執(zhí)行后間隔指定時間重復(fù)執(zhí)行
  • 啟動任務(wù)之后多久執(zhí)行
  • 啟動任務(wù)后多久執(zhí)行,執(zhí)行之后指定間隔多久重復(fù)執(zhí)行

3.使用方法

首先要通過繼承 TimerTask 類 并實現(xiàn) run() 方法來自定義要執(zhí)行的任務(wù)(當(dāng)然也可以寫成匿名內(nèi)部類),

需要創(chuàng)建一個定時器(Timer類對象),并通過Timer.schedule(TimerTask task,Date time) 方法執(zhí)行時間運行任務(wù)

具體代碼如下:

package timerdemo; 
import java.util.Timer;
import java.util.TimerTask; 
public class TimerDemo {
	public static void main(String[] args) {
		timerTest();
	}
	
	public static void timerTest(){
		//創(chuàng)建一個定時器
		Timer timer = new Timer();
		//schedule方法是執(zhí)行時間定時任務(wù)的方法
		timer.schedule(new TimerTask() {
			
			//run方法就是具體需要定時執(zhí)行的任務(wù)
			@Override
			public void run() {
				System.out.println("timer測試!!!");
			}
		}, 1000, 10000);
	}
}

這里的 schedule方法有4個,分別對應(yīng)上面說的四種情況:

4.啟動方法

1.在jar工程下啟動

把jar工程打成jar包,通過java -jar timer.jar 運行

2.這web工程下啟動

spring中我們可以通過實現(xiàn)接口ApplicationListener,并重寫public void onApplicationEvent(ApplicationEvent event) {}可以在容器初始話的時候執(zhí)行這個方法

下面展示下web工程下每天00:00執(zhí)行任務(wù)的代碼:

@Component
public class SystemInitListener implements ApplicationListener<ContextRefreshedEvent> { 
	@Override
	public void onApplicationEvent(ContextRefreshedEvent event) {
		
		//創(chuàng)建定時器
		Timer timer = new Timer();
		Calendar calendar = Calendar.getInstance();
        calendar.add(Calendar.DATE,1);
        calendar.set(calendar.get(Calendar.YEAR),calendar.get(Calendar.MONTH),calendar.get(Calendar.DATE),0,0,0);
        long timeInterval = 24 * 60 * 60 * 1000;
        timer.schedule(new TimerTask() {
			
			@Override
			public void run() {
				// 每天00:00需要做的事情				
			}
		}, calendar.getTime(), timeInterval);

java的幾種定時器小結(jié)

總結(jié)一下我使用過的4種類型的定時器:@Scheduled注解、quartz、new Timer().schedule、使用線程控制。

1.@Scheduled注解

@Scheduled注解是最簡單的方式,只需要啟用定時器,在方法上添加注解即可。

在spring配置中加入:

<!-- 啟用注解定時器 -->
 <task:annotation-driven />

在要具體的方法上加入注解@Scheduled

@Scheduled(cron = "0 0 * * * ? ")
    public void myTask(){
           //定時任務(wù)......
}

2.quartz

quartz使用的是可配置的方式,將所有的定時器都配置再一個xml文件里面。

步驟如下:

1.創(chuàng)建一個spring的配置文件:spring-quartz.xml

2.定義工作任務(wù)的job

3.定義觸發(fā)器Trigger并與job綁定

4.定義調(diào)度器,并將Trigger注冊到scheduler

   <bean id="myTask" class="cn.coolwind.MyTask"/>
 <!-- 1.定義工作任務(wù)job -->
    <bean id="testJob" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
        <!-- 定時器的類  -->
        <property name="targetObject" ref="myTask"></property>
        <!-- 需要定時執(zhí)行的方法  -->
        <property name="targetMethod" value="test"></property>
        <property name="concurrent" value="false"></property>
    </bean>
    <!-- 2.定義觸發(fā)器Trigger并與Job綁定 -->
    <bean id="testJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
        <property name="jobDetail" ref="testJob"/>
        <!-- 根據(jù)需要設(shè)置定時執(zhí)行的時間 -->
        <property name="cronExpression" value="0 0/5 * * * ?" />
    </bean>
 
   <!-- 3.定義調(diào)度器,并將trigger注冊進去 -->
<bean name="quartzScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
        <property name="triggers">
            <list>
                 <ref local="testJobTrigger" />
            </list>
        </property>
    </bean>

最后記得將xml寫入web.xml里!

    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>
    classpath:applicationContext.xml,
    classpath:log4j.xml,
                classpath:spring-quartz.xml
   </param-value>
    </init-param>

3.使用Timer

使用Timer的schedule,schedule有3個參數(shù):

schedule(TimerTask task, long delay, long period)

第一個為定時任務(wù),根據(jù)業(yè)務(wù)需要重寫TimerTask的run方法即可;

第二個為延時啟動,單位毫秒;

第三個位多久運行一次,單位毫秒;

new Timer().schedule(new TimerTask() {
            @Override
            public void run() {
                try {
                    //do Something
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        },0,5L * 60 * 1000);

4.使用線程控制

使用線程來控制就更靈活一些,可以根據(jù)自己的需要判斷什么時候運行,什么時候停止,這需要對java的線程有一定的了解。

public class TaskTest {
    private static final ExecutorService pool = Executors.newFixedThreadPool(5);// 線程池
    public static final TaskTest me = new TaskTest();
    public final int[] arr = new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9}; 
    public static void main(String[] args) {
        me.start();
    }
 
    private void start() {
        pool.execute(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        for (int i = 0; i < arr.length; i++) {
                            if (1 == arr[i]) {
                                System.out.println("start!");
                                Thread.sleep(1*1000L);
                            }
                            if (6 == arr[i]) {
                                System.out.println("stop!");
                                Thread.sleep(5*1000L);
                            }
                            System.out.println(arr[i]);
                            if (9 == arr[i]) {
                                System.out.println("end!");
                                Thread.sleep(5*1000L);
                            }
                        }
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        });
    }
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • springboot整合kaptcha驗證碼的示例代碼

    springboot整合kaptcha驗證碼的示例代碼

    kaptcha是一個很有用的驗證碼生成工具,本篇文章主要介紹了springboot整合kaptcha驗證碼的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Java多線程之Callable接口的實現(xiàn)

    Java多線程之Callable接口的實現(xiàn)

    這篇文章主要介紹了Java多線程之Callable接口的實現(xiàn),Callable和Runnbale一樣代表著任務(wù),區(qū)別在于Callable有返回值并且可以拋出異常。感興趣的小伙伴們可以參考一下
    2018-08-08
  • 使用IDEA反編譯沒有擦除泛型的原因解析

    使用IDEA反編譯沒有擦除泛型的原因解析

    Java泛型引入至今已有近20年,“偽泛型”已被認為是所有開發(fā)者的共識,沒有必要再在反編譯后體現(xiàn)出來反倒大大降低了可讀性,這篇文章主要介紹了使用IDEA反編譯沒有擦除泛型的原因解析,需要的朋友可以參考下
    2023-05-05
  • 詳解jvm對象的創(chuàng)建和分配

    詳解jvm對象的創(chuàng)建和分配

    這篇文章主要介紹了jvm對象的創(chuàng)建和分配的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-03-03
  • Java連接Oracle數(shù)據(jù)庫并查詢

    Java連接Oracle數(shù)據(jù)庫并查詢

    這篇文章主要介紹了Java連接Oracle數(shù)據(jù)庫并查詢的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • 深入XPath的詳解以及Java示例代碼分析

    深入XPath的詳解以及Java示例代碼分析

    本篇文章是對XPath進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • Java動態(tài)代理分析及理解

    Java動態(tài)代理分析及理解

    這篇文章主要介紹了Java動態(tài)代理分析及理解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Java 在PPT中添加文本和圖片超鏈接的實現(xiàn)方法

    Java 在PPT中添加文本和圖片超鏈接的實現(xiàn)方法

    這篇文章主要介紹了Java 在PPT中添加文本和圖片超鏈接的實現(xiàn)方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • Java?BOI與NIO超詳細實例精講

    Java?BOI與NIO超詳細實例精講

    在Java的軟件設(shè)計開發(fā)中,通信架構(gòu)是不可避免的,我們在進行不同系統(tǒng)或者不同進程之間的數(shù)據(jù)交互,或者在高并發(fā)下的通信場景下都需要用到網(wǎng)絡(luò)通信相關(guān)的技術(shù),對于一些經(jīng)驗豐富的程序員來說,Java早期的網(wǎng)絡(luò)通信架構(gòu)存在一些缺陷,這篇文章介紹Java?BOI與NIO
    2022-11-11
  • Spring中的ImportBeanDefinitionRegistrar接口詳解

    Spring中的ImportBeanDefinitionRegistrar接口詳解

    這篇文章主要介紹了Spring中的ImportBeanDefinitionRegistrar接口詳解,ImportBeanDefinitionRegistrar接口是也是spring的擴展點之一,它可以支持我們自己寫的代碼封裝成BeanDefinition對象,注冊到Spring容器中,功能類似于注解@Service @Component,需要的朋友可以參考下
    2023-09-09

最新評論