Android 实现定时任务的过程详解

在Android开发中,通过以下三种方法定时执行任务:

一、采用Handler与线程的sleep(long)方法(不建议使用,java的实现方式)

二、采用Handler的postDelayed(Runnable, long)方法(最简单的android实现)

三、采用Handler与timer及TimerTask结合的方法(比较多的任务时建议使用)

android里有时需要定时循环执行某段代码,或者需要在某个时间点执行某段代码,这个需求大家第一时间会想到Timer对象,没错,不过我们还有更好的选择。

 一、Timer 实现定时任务

Timer timer;
void onCreate(){
 ......
TimerTask task = new TimerTask(){
public void run(){
 // 在此处添加执行的代码
}
};
timer = new Timer();
timer.schedule(task, 1000);//开启定时器,delay 1s后执行task
}
void onDestroy(){
......
timer.cancel();//销毁定时器
}

二、Handler实现定时任务

1.隔一段时间后执行某个操作,循环执行:

void onCreate(){
 ......
 Handler handler = new Handler();
 Runnable runnable = new Runnable(){
  @Override
  public void run() {
  // TODO Auto-generated method stub
  // 在此处添加执行的代码
  handler.postDelayed(this, 50);// 50ms后执行this,即runable
  }
 };
 handler.postDelayed(runnable, 50);// 打开定时器,50ms后执行runnable操作
}
void onDestroy(){
 ......
 handler.removeCallbacks(this);// 关闭定时器处理
}

2.隔一段时间后执行某个操作一次,执行完后,不再执行:

void onCreate(){
......
Handler handler = new Handler();
 Runnable runnable = new Runnable(){
 @Override
 public void run() {
  // TODO Auto-generated method stub
  // 在此处添加执行的代码
              doSomeThing();
  handler.removeCallbacks(this); //移除定时任务
   }
 };
 handler.postDelayed(runnable, 50);// 打开定时器,50ms后执行runnable
}

三、AlarmManager实现精确定时操作

我们使用Timer或者handler的时候会发现,delay时间并没有那么准。如果我们需要一个严格准时的定时操作,那么就要用到AlarmManager,AlarmManager对象配合Intent使用,可以定时的开启一个Activity,发送一个BroadCast,或者开启一个Service.

下面的代码详细的介绍了两种定时方式的使用:

在指定时长后执行某项操作

// 以下的代码是<<足球即时比分>>中的代码片段.
 public static AlarmManagerUtil{
   public static AlarmManager getAlarmManager(Context ctx){
   return (AlarmManager) ctx.getSystemService(Context.ALARM_SERVICE);
  }
  /**
  * 指定时间后进行更新赛事信息(有如闹钟的设置)
  * 注意: Receiver记得在manifest.xml中注册
   *
  * @param ctx
  */
  public static void sendUpdateBroadcast(Context ctx){
   Log.i("score", "send to start update broadcase,delay time :"+);
   larmManager am = getAlarmManager(ctx);
    // 秒后将产生广播,触发UpdateReceiver的执行,这个方法才是真正的更新数据的操作主要代码
   Intent i = new Intent(ctx, UpdateReceiver.class);
   PendingIntent pendingIntent = PendingIntent.getBroadcast(ctx, , i, );
   am.set(AlarmManager.RTC, System.currentTimeMillis()+, pendingIntent)
 }
  /**
  * 取消定时执行(有如闹钟的取消)
  *
  * @param ctx
  */
  public static void cancelUpdateBroadcast(Context ctx){
   AlarmManager am = getAlarmManager(ctx);
   Intent i = new Intent(ctx, UpdateReceiver.class);
   PendingIntent pendingIntent = PendingIntent.getBroadcast(ctx, , i, );
   am.cancel(pendingIntent);
  }
 }
 // 更新数据库的广播接收器
 public static class UpdateReceiver extends BroadcastReceiver{
   public void onReceive(Context context, Intent intent) {
    Toast.makeText(context, "更新比分数据", Toast.LENGTH_LONG).show();
    // 设置全局定时器(闹钟) 秒后再发广播通知本广播接收器触发执行.
    // 这种方式很像JavaScript中的 setTimeout(xxx,)
    AlarmManagerUtil.sendUpdateBroadcast(context);
   }
  }

周期性的执行某项操作

publicstaticvoid sendUpdateBroadcastRepeat(Context ctx){
 Intent intent =new Intent(ctx, UpdateReceiver.class);
 PendingIntent pendingIntent = PendingIntent.getBroadcast(ctx, 0, intent, 0);
 //开始时间
 long firstime=SystemClock.elapsedRealtime();
 AlarmManager am = (AlarmManager) ctx.getSystemService(ALARM_SERVICE);
  //60秒一个周期,不停的发送广播
 am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, firstime, 60*1000, pendingIntent);
}

取消定时器(闹钟)

/**
 * 取消定时执行(有如闹钟的取消)
 *
 * @param ctx
 */publicstaticvoid cancelUpdateBroadcast(Context ctx){
  AlarmManager am = getAlarmManager(ctx);
  // 取消时注意UpdateReceiver.class必须与设置时一致,这样才要正确取消
  Intent i = new Intent(ctx, UpdateReceiver.class);
  PendingIntent pendingIntent = PendingIntent.getBroadcast(ctx, 0, i, 0);
  am.cancel(pendingIntent);
 }
}

以上所述是小编给大家介绍的Android 定时任务过程详解,希望大家喜欢。

(0)

相关推荐

  • Android闹钟机制实现定时任务功能

    Android的闹钟实现机制, 需要调用AlarmManager.set()将闹铃时间记录到系统中,当闹铃时间到后,系统会给应用程序发送广播,我们只需要去注册广播接收器就可以了. 本文分三部分讲解如何实现闹钟: 目录: 1. 设置闹铃时间; 2. 接收闹铃事件广播; 3. 重开机后重新计算并设置闹铃时间; 1. 设置闹铃时间(毫秒) private void setAlarmTime(Context context, long triggerAtMillis) { AlarmManager am

  • Android实现定时任务功能

    本文实例为大家分享了Android实现定时任务功能的具体代码,供大家参考,具体内容如下 1.采用Handle与线程的sleep(long)方法 (1).定义一个Handler类,用于处理接受到的Message. Handler handler = new Handler() {       public void handleMessage(Message msg) {           // 要做的事情           super.handleMessage(msg);       }

  • Android实现定时任务及闹钟

    android中定时有很多种是实现,常见的Handler 与Thread的结合,handler.postDelayed ,以及要使用的AlarmManger 等都可以实现定时任务的执行,但是使用场景却大不相同,这里主要是怎么用AlarmManager实现定时任务. 涉及知识点: 1)BroadCastReceiver任务接收 2)CountDownTimer倒计时 3)AlertDialog 任务提醒 4)AlarmManager 定时任务 这里实现的需求时每天定时24点关机,有设备是定制系统,

  • 一个简单的Android定时任务

    使用AlarmManager来实现定时提醒,它提供了一种访问系统闹钟服务的方式.在全局中,达到设定的时间, 在它上面注册的一个Intent将会被广播,接着启动相应的应用程序,可以通过自定义Receiver来实现. 首先要在AndroidManifest.xml中进行注册 <receiver android:name=".AlarmReceiver"> <intent-filter> <action android:name="CLOCK"

  • Android 实现定时任务的过程详解

    在Android开发中,通过以下三种方法定时执行任务: 一.采用Handler与线程的sleep(long)方法(不建议使用,java的实现方式) 二.采用Handler的postDelayed(Runnable, long)方法(最简单的android实现) 三.采用Handler与timer及TimerTask结合的方法(比较多的任务时建议使用) android里有时需要定时循环执行某段代码,或者需要在某个时间点执行某段代码,这个需求大家第一时间会想到Timer对象,没错,不过我们还有更好的

  • Android动态使用VectorDrawable过程详解

    目录 导言 案例演示 问题解决 接上篇继续,讲解使用动态的VectorDrawable 上篇链接: Android三种方式生成矢量图之VectorDrawable类使用详解 导言 VectorDrawable有两个优点,一个是缩放不失真,另一个是使PNG的体积,大幅度减小,那么如果仅仅只有这两个优点,其实我是并不需要使用VectorDrawable,或者说,这并不能成为我们使用VectorDrawable的重要原因. 那我们使用它的重要原因是什么呢? 那就是VectorDrawable可以使用动

  • Android Touch事件分发过程详解

    本文以实例形式讲述了Android Touch事件分发过程,对于深入理解与掌握Android程序设计有很大的帮助作用.具体分析如下: 首先,从一个简单示例入手: 先看一个示例如下图所示: 布局文件 : <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id=&

  • Android 应用的安装过程详解

    Android 应用安装过程: 首先一个android项目,然后编译和打包,将.java文件编译为.class,.class编译为.dex,将所有文件打包为一个apk,只编译代码,不编译资源. .apk里面的.arsc是资源的索引,当资源比较多的时候,可以索引. signing-签名,系统在确认应用被覆盖之前,除了检测包名是否一致,还会检测签名是否相同.所以签名是一个公司的机密,起到版权保护的作用. 我们部署一个项目,不是把项目安装到手机上,而是先把apk安装包上传拷贝到手机上,在手机里面安装这

  • Android 定时任务过程详解

    在Android开发中,通过以下三种方法定时执行任务: 一.采用Handler与线程的sleep(long)方法(不建议使用,java的实现方式) 二.采用Handler的postDelayed(Runnable, long)方法(最简单的android实现) 三.采用Handler与timer及TimerTask结合的方法(比较多的任务时建议使用) android里有时需要定时循环执行某段代码,或者需要在某个时间点执行某段代码,这个需求大家第一时间会想到Timer对象,没错,不过我们还有更好的

  • Android Studio3.2中导出jar包的过程详解

    1.)说明. 本项目是来自github上的一个项目roottools (https://github.com/Stericson/RootTools),这里只是想本地编译后输出下jar包供自己进行使用. 2.)操作步骤. 步骤1)按之前你熟悉的方式进行开发待输出为jar的项目. 步骤2) 一般的gradle设置,比如gradle版本,android sdk的编译,目标,最小要求版本..还有compileOptions的jdk版本设置等. 步骤3)gradle中的apply plugin设置: a

  • android中使用react-native设置应用启动页过程详解

    一.背景 在我们使用react-native进行编写代码的时候,当启动应用的时候,我们会看到如下界面 然而,这样的启动界面是非常的不又好,那么我们该怎么进行处理启动界面呢?有如下两种方案 二.方案 1.使用第三方库(react-native-splash-screen) 2.ios系统设置(仅适用ios系统,在这里不做讲解) 三.具体实现方式 一).react-native-splash-screen 1.安装 npm i react-native-splash-screen --save 2.

  • Taro打包Android apk过程详解

    首先,我们使用使用命令创建模板项目,创建的命令如下. taro init myApp 然后,使用 yarn 或者 npm install安装依赖包,并使用下面的命令编译Taro项目. yarn dev:rn 启动后会开启一个监听的进程. 不过,细心的你可能会发现,使用taro init命令初始化的项目是没有原生模块支持的,原来Taro使用了一个壳子工程,首先使用下面的命令下载壳子工程taro-native-shell,如下所示. git clone git@github.com:NervJS/t

  • Android DaggerActivityComponent错误解决办法详解

    Android DaggerActivityComponent错误解决办法详解 在使用dagger2的过程中,如果修改了某个类的内容,第一次编译运行时总会报错:错误: 找不到符号 符号: 类 DaggerActivityComponent 位置: 程序包 com--的错误,然后再重新编译一次,才会正常运行,经过仔细的检查终于找到问题的根源: 错误的原因是build.gradle(Module:app)引入'com.google.dagger:dagger-compiler:2.0.2'使用的是c

  • Android 捕获运行时异常详解

    Android 捕获运行时异常详解 Android 异常分为两类:CheckedException 和 UnCheckedException CheckException:在编译代码时就需要进行try()catch捕获的. UnCheckException:所有的运行时异常,RuntimeException类和他的子类,都是在APP运行的过程中的发生的.即:APP在运行的过程中崩溃了,这种异常我们就成为运行时异常(比如空指针),当APP崩溃的时候,给用户的体验很不好,所以我们应该捕获这个异常进行

随机推荐