import?java.io.IOException;
創(chuàng)新互聯(lián)公司主要從事網(wǎng)站制作、成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)槐蔭,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792
import?java.util.Timer;
public?class?TimerTest?{
public?static?void?main(String[]?args)?{
Timer?timer?=?new?Timer();
timer.schedule(new?MyTask(),?1000,?2000);//?在1秒后執(zhí)行此任務(wù),每次間隔2秒,如果傳遞一個(gè)Data參數(shù),就可以在某個(gè)固定的時(shí)間執(zhí)行這個(gè)任務(wù).
while?(true)?{//?這個(gè)是用來停止此任務(wù)的,否則就一直循環(huán)執(zhí)行此任務(wù)了
try?{
int?ch?=?System.in.read();
if?(ch?-?'c'?==?0)?{
timer.cancel();//?使用這個(gè)方法退出任務(wù)
}
}?catch?(IOException?e)?{
//?TODO?Auto-generated?catch?block
e.printStackTrace();
}
}
}
static?class?MyTask?extends?java.util.TimerTask?{
@Override
public?void?run()?{
//?TODO?Auto-generated?method?stub
System.out.println("________");
}
}
}
這段代碼基本能滿足你需求了 你還有需求就在上面再套一層job 當(dāng)然如過太復(fù)雜了而且這種定時(shí)需求很多的話 建議用quartz框架 使用很簡單
我是讓它每10毫秒掃描一下。
Calendar ca=null;
Calendar ca1=null;
Timer timer=new Timer();
static Connection con=null;
public void chu(){
ca=Calendar.getInstance();
ca1=(Calendar)ca.clone();
ca1.add(Calendar.SECOND, 20);
}
public void Time(){
float s=ca1.get(Calendar.SECOND)-ca.get(Calendar.SECOND)+(ca1.get(Calendar.MILLISECOND)-ca.get(Calendar.MILLISECOND))/1000f;
if(con==null){
System.out.println("耗時(shí)"+String.valueOf(s)+"秒");
if(ca.after(ca1)){
System.out.println("取不到連接");
timer.cancel();
return ;
}
}else{
System.out.println("耗時(shí)"+String.valueOf(s)+"秒");
}
ca.add(Calendar.MILLISECOND, 10);
timer.schedule(
new TimerTask() {
public void run() {
System.out.println("時(shí)間在溜走。。。。");
Time();
}
}, ca.getTime());
}
void getcon(){
Connection con=null;//獲取Connection
chu();
Time();
}
JDK 自帶的定時(shí)器實(shí)現(xiàn)
// schedule(TimerTask task, long delay) 延遲 delay 毫秒 執(zhí)行
// schedule(TimerTask task, Date time) 特定時(shí)間執(zhí)行
public static void main(String[] args) {
for (int i = 0; i 10; ++i) {
new Timer("timer - " + i).schedule(new TimerTask() {
@Override
public void run() {
println(Thread.currentThread().getName() + " run ");
}
}, 1000);
}
}
2. Quartz 定時(shí)器實(shí)現(xiàn)
//首先我們需要定義一個(gè)任務(wù)類,比如為MyJob02 ,
//該類需要繼承Job類,然后添加execute(JobExecutionContext context)方法,在
//這個(gè)方法中就是我們具體的任務(wù)執(zhí)行的地方。
//由希望由調(diào)度程序執(zhí)行的組件實(shí)現(xiàn)的接口
public class MyJob02 implements Job {
@Override
public void execute(JobExecutionContext context) throws JobExecutionException {
// TODO Auto-generated method stub
// 執(zhí)行響應(yīng)的任務(wù).
System.out.println("HelloJob.execute,"+new Date());
}
}
public class QuartzTest5 {
public static void main(String[] args) throws Exception {
//SchedulerFactory 是一個(gè)接口,用于Scheduler的創(chuàng)建和管理
SchedulerFactory factory = new StdSchedulerFactory();
//從工廠里面拿到一個(gè)scheduler實(shí)例
//計(jì)劃表(可能翻譯的不太貼切),現(xiàn)在我們有了要做的內(nèi)容,
//與調(diào)度程序交互的主要API
/*
* Scheduler的生命期,從SchedulerFactory創(chuàng)建它時(shí)開始,
到Scheduler調(diào)用shutdown()方法時(shí)結(jié)束;Scheduler被創(chuàng)建后,
可以增加、刪除和列舉Job和Trigger,以及執(zhí)行其它與調(diào)度相關(guān)的操作
(如暫停Trigger)。但是,Scheduler只有在調(diào)用start()方法后,
才會(huì)真正地觸發(fā)trigger(即執(zhí)行job)
*/
Scheduler scheduler = factory.getScheduler();
//具體任務(wù).
//用于定義作業(yè)的實(shí)例
//JobBuilder - 用于定義/構(gòu)建JobDetail實(shí)例,用于定義作業(yè)的實(shí)例。
JobDetail job = JobBuilder.newJob(MyJob.class).withIdentity("job1", "group1").build();
//Trigger(即觸發(fā)器) - 定義執(zhí)行給定作業(yè)的計(jì)劃的組件
//TriggerBuilder - 用于定義/構(gòu)建觸發(fā)器實(shí)例
CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1")
.withSchedule(CronScheduleBuilder.cronSchedule("0/1? * * * * ?")).build();
scheduler.scheduleJob(job, trigger);
scheduler.start();
}
3. Spring? boot 任務(wù)調(diào)度(這個(gè)非常容易實(shí)現(xiàn))
/*
*? 開啟對定時(shí)任務(wù)的支持
*? 在相應(yīng)的方法上添加@Scheduled聲明需要執(zhí)行的定時(shí)任務(wù)。
*/
@EnableScheduling
//@EnableScheduling注解來開啟對計(jì)劃任務(wù)的支持
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
@Component
public class ScheduledTasks {
private Logger logger = LoggerFactory.getLogger(ScheduledTasks.class);
private??? int???? i=0;
//0 0 0 2 * ?
@Scheduled(cron="*? *? *? 2? *? ?")
//@Scheduled 注解用于標(biāo)注這個(gè)方法是一個(gè)定時(shí)任務(wù)的方法
public void testFixDelay() {
logger.info("執(zhí)行方法"+i++);
}
這個(gè)是我在網(wǎng)上找的不知道是不是你要的:
java定時(shí)任務(wù)Timer 關(guān)于定時(shí)任務(wù),似乎跟時(shí)間操作的聯(lián)系并不是很大,但是前面既然提到了定時(shí)任務(wù),索性在這里一起解決了。設(shè)置定時(shí)任務(wù)很簡單,用Timer類就搞定了。一、延時(shí)執(zhí)行首先,我們定義一個(gè)類,給它取個(gè)名字叫TimeTask,我們的定時(shí)任務(wù),就在這個(gè)類的main函數(shù)里執(zhí)行。代碼如下:
package test;
import java.util.Timer;
public class TimeTaskTest {
public static void main(String[] args){ Timer timer = new Timer();
timer.schedule(new Task(), 60 * 1000);
}
}
解釋一下上面的代碼。上面的代碼實(shí)現(xiàn)了這樣一個(gè)功能,當(dāng)TimeTask程序啟動(dòng)以后,過一分鐘后執(zhí)行某項(xiàng)任務(wù)。很簡單吧:先new一個(gè)Timer對象,然后調(diào)用它的schedule方法,這個(gè)方法有四個(gè)重載的方法,這里我們用其中一個(gè),
public void schedule(TimerTask task,long delay)
首先,第一個(gè)參數(shù)第一個(gè)參數(shù)就是我們要執(zhí)行的任務(wù)。這是一個(gè)TimerTask對象,確切點(diǎn)說是一個(gè)實(shí)現(xiàn)TimerTask的類的對象,因?yàn)門imerTask是個(gè)抽象類。上面的代碼里 面,Task就是我們自己定義的實(shí)現(xiàn)了TimerTask的類,因?yàn)槭窃谕粋€(gè)包里面,所以沒有顯性的import進(jìn)來。Task類的代碼如下
package test;
import java.util.TimerTask;
public class Task extends TimerTask { public void run()
{
System.out.println("定時(shí)任務(wù)執(zhí)行");
}
}
我們的Task必須實(shí)現(xiàn)TimerTask的方法run,要執(zhí)行的任務(wù)就在這個(gè)run方法里面,這里,我們只讓它往控制臺(tái)打一行字。第二個(gè)參數(shù)第二個(gè)參數(shù)是一個(gè)long型的值。這是延遲的時(shí)間,就是從程序開始以后,再過多少時(shí)間來執(zhí)行定時(shí)任務(wù)。這個(gè)long型的值是毫秒數(shù),所以前面我們的程序里面,過一分鐘后執(zhí)行用的參數(shù)值就是 60 * 1000。二、循環(huán)執(zhí)行設(shè)置定時(shí)任務(wù)的時(shí)候,往往我們需要重復(fù)的執(zhí)行這樣任務(wù),每隔一段時(shí)間執(zhí)行一次,而上面的方法是只執(zhí)行一次的,這樣就用到了schedule方法的是另一個(gè)重載函數(shù)public void schedule(TimerTask task,long delay,long period)
前兩個(gè)參數(shù)就不用說什么了,最后一個(gè)參數(shù)就是間隔的時(shí)間,又是個(gè)long型的毫秒數(shù)(看來java里涉及到時(shí)間的,跟這個(gè)long是脫不了干系了),比如我們希望上面的任務(wù)從第一次執(zhí)行后,每個(gè)一分鐘執(zhí)行一次,第三個(gè)參數(shù)值賦60 * 1000就ok了。三、指定執(zhí)行時(shí)間既然號(hào)稱是定時(shí)任務(wù),我們肯定希望由我們來指定任務(wù)指定的時(shí)間,顯然上面的方法就不中用了,因?yàn)槲覀儾恢莱绦蚴裁磿r(shí)間開始運(yùn)行,就沒辦法確定需要延時(shí)多少。沒關(guān)系,schedule四個(gè)重載的方法還沒用完呢。用下面這個(gè)就OK了:
public void schedule(TimerTask task,Date time)
比如,我們希望定時(shí)任務(wù)2006年7月2日0時(shí)0分執(zhí)行,只要給第二個(gè)參數(shù)傳一個(gè)時(shí)間設(shè)置為2006年7月2日0時(shí)0分的Date對象就可以了。有一種情況是,可能我們的程序啟動(dòng)的時(shí)候,已經(jīng)是2006年7月3日了,這樣的話,程序一啟動(dòng),定時(shí)任務(wù)就開始執(zhí)行了。schedule最后一個(gè)重載的方法是public void schedule(TimerTask task,Date firstTime,long period)
沒必要說什么了吧:)四、j2ee中的定時(shí)任務(wù)在實(shí)際的項(xiàng)目中,往往定時(shí)任務(wù)需要對web工程中的資源進(jìn)行操作,這樣一來,用上面的單個(gè)程序的方式可能就有點(diǎn)力不從心了,因?yàn)楹芏鄔eb工程的資源它操作不到。解決的辦法是,使用Servlet,把執(zhí)行定時(shí)任務(wù)的那些代碼放到Servlet的init()函數(shù)里就可以了,這個(gè)easy,就沒有必要再寫示例代碼了吧
Java 基本的定時(shí)任務(wù),總結(jié)方法有三種:
1?? 創(chuàng)建一個(gè)thread,然后讓它在while循環(huán)里一直運(yùn)行著,通過sleep方法來達(dá)到定時(shí)任務(wù)的效果;
2?? 用Timer和TimerTask與第一種方法相比有如下好處:
當(dāng)啟動(dòng)和去取消任務(wù)時(shí)可以控制
第一次執(zhí)行任務(wù)時(shí)可以指定你想要的delay時(shí)間
3?? 用ScheduledExecutorService是從的java.util.concurrent里,做為并發(fā)工具類被引進(jìn)的,這是最理想的定時(shí)任務(wù)實(shí)現(xiàn)方式,相比于上兩個(gè)方法,它有以下好處:
相比于Timer的單線程,它是通過線程池的方式來執(zhí)行任務(wù)的
可以很靈活的去設(shè)定第一次執(zhí)行任務(wù)delay時(shí)間
提供了良好的約定,以便設(shè)定執(zhí)行的時(shí)間間隔
本文題目:java代碼實(shí)現(xiàn)定時(shí)器,java的定時(shí)器可以提供實(shí)時(shí)保證
文章URL:http://sd-ha.com/article30/hcoiso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、定制網(wǎng)站、微信公眾號(hào)、營銷型網(wǎng)站建設(shè)、商城網(wǎng)站、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)