<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 60,comments - 71,trackbacks - 0

         在要定時執行某一任務時,在精度不是要求很高的情況下,一般使用Java.util.TimerTask類來完成(要精確度較高的要求下可采用Quarta開源插件),使用
    TimerTask類完成定時任務開發時,很簡單,只需以下二步:
    !)定義一個繼承TimerTask類的類,重寫run()方法,在該方法中實現自已的業務邏輯;
    2)在主類中定義一個Timer類對象,用該對象的schedule()或scheduleAtFixedRate()來實現定時任務的執行(這兩個方法有一定的區別,這里不作介紹);

    這樣就完成了任務的定時執行,其實 TimerTask類也是基于線程(Thread)的實現,所以繼承了TimerTask的類要重寫run()方法,在該方法中實現自已的任務.

    現在有一點要說明下,即在創建Timer類對象時,有兩種方法:
    1)Timer tm = new Timer(); //創建一個非守護線程
    2)Timer tm = new Timer(true);
    //創建一守護線程

    讓timer線程成為一個daemon線程,這樣當程序只有daemon線程的時候,它就會自動終止運行.如果有非守護線程在運行,則守護線程一直存在.
    現舉例如下:
    1)
        public static void main(String[] args) {

            Timer tm 
    = new Timer(true); //創建一守護線程
            tm.schedule(
    new TestTask(),2*1000);
    }
     
    TestTask()類中重寫的run()方法很簡單,只是輸出一條語句,但這段代碼是沒有輸出結果的,因為主線程啟動后就停止了,所以tm這個守護線程就也不存在了,所以沒有輸出結果,現在改下代碼:
    2)
     public static void main(String[] args) {
           
            
    try {
             Thread.sleep(
    6*1000);
            }

            
    catch(Exception e) {
               e.printStackTrace();
            }

            Timer tm 
    = new Timer(true);
            tm.schedule(
    new TestTask(),2*1000);
    }

    但這段代碼也還是沒有輸出的,因為主線程睡眠了6秒鐘后,守護線程才產生,但這時主線程睡眠了6秒鐘后就已經消亡了,所以守護線程就也不存在了,但如果讓主線程睡眠放在schedule()方法后面執行,則就會有輸出,即:
    3)
    Timer tm = new Timer(true);//創建一守護線程

            tm.schedule(
    new TestTask(),2*1000);

            
    try {
                Thread.sleep(
    6*1000);
            }

            
    catch(Exception e) {
                e.printStackTrace();
            }
    這是會有輸出的,因為主線程啟動后,守護線程也啟動了,而主線程睡眠6秒鐘,守護線程過2秒后執行,2秒時間在6秒時間內,所以在主線程消亡之前,守護線程還存在,所以有輸出,但要保證主線程睡眠的時間大于或等于(等于的情況我試過幾次,都有輸出,但不保證一定會有輸出,因為TimerTask有定時不精確的情況)定時任務的時間段(這里是2秒),即如果這里設為7秒或大于6秒的其它值,是不會有輸出的.

    另:這里有幾種情況要說明下:
    1)上面幾種例舉的情況是指創建守護線程(即創建Timer對象時帶true這個參數,如果不帶參數,則表示創建的是非守護線程)的情況,如果創建的是非守護線程,則不管哪種情況,一定會有輸出的.
    2)針對上面幾種情況,如果在調用schedule()方法時,使用的是三個參數的(上面都是帶兩個參數),且第二個參數為0的話,則上面的幾種情況,也都是會有輸出的,因為第二個參數為0的話,表示的意思是立即執行.如上面第二種情況,如果改成這樣:tm.schedule(new TestTask(),0,2*1000);守護線程雖然后是等主線程睡眠6秒主才產生(且這時主線程已經消亡),但產生守護線程時,守護線程立即執行,所以也會能輸出.

    注:守護線程的特點是,只要線程隊列中沒有非守護線程(即普通的我們常見的線程都為非守護線程),則所有的守護線程也將全部消亡.
    創建守護線程的方法是,線程對象調用: threadObj.setDaemon(true);即可將threadObj該線程設為守護線程.
    posted on 2008-05-28 10:01 henry1451 閱讀(735) 評論(0)  編輯  收藏 所屬分類: Java技術
    主站蜘蛛池模板: 久久WWW免费人成—看片| 亚洲av永久无码天堂网| 男女啪啪免费体验区| 日韩免费高清视频| 亚洲欧美日韩综合久久久| 成人免费午夜在线观看| 精品久久久久久亚洲精品| 无码国产精品一区二区免费式直播| 蜜芽亚洲av无码精品色午夜| 免费高清国产视频| 亚洲高清资源在线观看| 一级毛片aaaaaa视频免费看| 成人免费视频软件网站| 亚洲欧美成aⅴ人在线观看| 精品无码国产污污污免费| 亚洲爆乳少妇无码激情| 亚洲av中文无码| 成人网站免费大全日韩国产| 亚洲动漫精品无码av天堂| 18女人腿打开无遮掩免费| 亚洲国产高清美女在线观看| 毛片免费视频播放| 直接进入免费看黄的网站| 亚洲精品国产电影| 日本视频免费高清一本18| 亚洲精品国产免费| 日韩视频免费在线| 久久免费99精品国产自在现线| 久久精品国产亚洲| 特级做A爰片毛片免费69| 怡红院亚洲红怡院在线观看| 亚洲精品无码鲁网中文电影| aⅴ在线免费观看| 色婷婷亚洲一区二区三区| 日本亚洲国产一区二区三区| 18禁止看的免费污网站| 亚洲av无码专区亚洲av不卡| 国产亚洲精品自在久久| 美女网站免费福利视频| jizz免费一区二区三区| 亚洲国产美女在线观看|