注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

民主与科学

独立之人格,自由之思想

 
 
 

日志

 
 

Timer技术  

2010-06-22 11:33:58|  分类: Android基础 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
Class Overview
 java.util.Timer are used to schedule jobs for execution in a background process.
 A single thread is used for the scheduling and this thread has the option of being a daemon thread.
 By calling cancel you can terminate a Timer and its associated thread. 

 All tasks which are scheduled to run after this point are cancelled. 
 Tasks are executed sequentially but are subject to the delays from other tasks run methods. 
 If a specific task takes an excessive amount of time to run it may impact the time at which subsequent tasks may run.
 The TimerTask does not offer any guarantees about the real-time nature of scheduling tasks
 as its underlying implementation relies on the Object.wait(long) method.
 Multiple threads can share a single Timer without the need for their own synchronization.
 
 A Timer can be set to schedule tasks either at a fixed rate or with a fixed period.
 Fixed-period execution is the default.
 The difference between fixed-rate and fixed-period execution is the following: With fixed-rate execution, 
 the start time of each successive run of the task is scheduled in absolute terms without regard for when the previous task run actually took place.
 This can result in a series of bunched-up runs (one launched immediately after another) 
 if busy resources or other system delays prevent the Timer from firing for an extended time.
 With fixed-period execution, each successive run of the task is scheduled relative to the start time of the previous run of the task, 
 so two runs of the task are never fired closer together in time than the specified period.

 Timers主要是用来在后台运行一些任务。可以把Timer设置为守护线程。当调用cancel时所有已经安排的任务都没会被取消。
 Timer中的任务是依次执行的,如果一个任务花很长时间才执行完,那么它就可能影响下一个任务的开始执行的时间。
 TimerTask对任务的实时调度并没有保证,因为作为底层的实现依赖于Object.wait(long)方法。
 注意:守护线程就是一直运行,即使任务完成也不会停止的线程。详细内容请参考《守护线程
 构造函数
Public Constructors
Timer(String name, boolean isDaemon)
Creates a new named Timer which may be specified to be run as a daemon thread.
Timer(String name)
Creates a new named Timer which does not run as a daemon thread.
Timer(boolean isDaemon)
Creates a new Timer which may be specified to be run as a daemon thread.
Timer()
Creates a new non-daemon Timer.
主要方法

Public Methods
voidcancel()
Cancels the Timer and all scheduled tasks.
intpurge()
Removes all canceled tasks from the task queue.
voidschedule(TimerTask task, Date when, long period)
Schedule a task for repeated fixed-delay execution after a specific time has been reached.
voidschedule(TimerTask task, long delay, long period)
Schedule a task for repeated fixed-delay execution after a specific delay.
voidschedule(TimerTask task, Date when)
Schedule a task for single execution.
voidschedule(TimerTask task, long delay)
Schedule a task for single execution after a specified delay.
voidscheduleAtFixedRate(TimerTask task, long delay, long period)
Schedule a task for repeated fixed-rate execution after a specific delay has passed.
delay时间后开始执行第一次,从此以后每隔period又开始执行,即使当前还有其他的任务在执行,它也会被调度并执行。
voidscheduleAtFixedRate(TimerTask task, Date when, long period)
Schedule a task for repeated fixed-rate execution after a specific time has been reached.
when时间开始执行第一次,从此以后每隔period又开始执行,即使当前还有其他的任务在执行,它也会被调度并执行。
Timer有两种调度模式fixed-rate(固定调度周期模式),fixed-period(完整执行周期模式)。默认的是fixed-period。
 fixed-period
    public void  schedule  (TimerTask  task, long delay, long period)
  Schedule a task for repeated fixed-delay execution after a specific delay.  schedule  (TimerTask  task, Date  when, long period)
 在delay时间后开始执行第一次,从此以后每隔period又开始执行。如果时间到了,但是当前还有其他的任务在执行,
 它只有等当前任务执行完了,才能被调度并执行。

 fixed-rate:
 public void  scheduleAtFixedRate  (TimerTask  task, long delay, long period)
 public void scheduleAtFixedRate  (TimerTask  task, Date  when, long period)
 在delay时间后开始执行第一次,从此以后每隔period又开始执行,即使当前还有其他的任务在执行,它也会被调度并执行。

因为Timer本身自己是新开了一个线程的,所以为了线程安全,不要在他里面做UI方面的操作。如果需要做UI的话,请通过一个Handler来在UI线程中来进行操作。
关于Handler请参考《关于Handler技术》和《Looper和Handler》.
关于Android的线程模型请参考《Android线程模型
 比如下面的代码就准不正确:
 package com.ray.test;  
 import java.util.Timer;  
 import java.util.TimerTask;  
 import android.app.Activity;  
 import android.os.Bundle;  
 public class JavaTimer extends Activity {  
  Timer timer = new Timer();  
  TimerTask task = new TimerTask(){  
   public void run() {  
   setTitle("hear me?");  
   }  
  };  
  
public void onCreate(Bundle savedInstanceState) {  
   super.onCreate(savedInstanceState);  
   setContentView(R.layout.main);  
   timer.schedule(task, 10000);  
  }  
 } 

 正确的做法应该通过配合基于UI线程的Handler来进行UI的操作。
 正确代码如下:
 package com.ray.test;   
 import java.util.Timer;   
 import java.util.TimerTask;   
 import android.app.Activity;   
 import android.os.Bundle;   
 import android.os.Handler;   
 import android.os.Message;   
 
public class TestTimer extends Activity {   
   Timer timer = new Timer();   
   Handler handler = new Handler(){   
   public void handleMessage(Message msg) {   
    switch (msg.what) {   
    case 1:   
    setTitle("hear me?");   
    break;   
    }   
    super.handleMessage(msg);   
   }   
  };   
  TimerTask task = new TimerTask(){   
   public void run() {   
   Message message = new Message();   
   message.what = 1;   
   handler.sendMessage(message);   
   }   
  };
   
  public void onCreate(Bundle savedInstanceState) {   
   super.onCreate(savedInstanceState);   
   setContentView(R.layout.main);   
   timer.schedule(task, 10000);   
  }   
 } 
  评论这张
 
阅读(763)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017