关闭

后台执行的定时任务

687人阅读 评论(0) 收藏 举报
分类:

在后台实现定时任务,我们可以用Alarm机制,开启服务来实现。

首先来介绍一下Alarm机制,它主要是借助了AlarmManager类来实现的。这个类和NotificationManager有点类似,都是通过调用Context的getSystemService()方法来获取实例的,只是这里需要传入的参数是Contex_ALARM_SERVICE。

因此,获取一个AlarmManager的实例就可以写成:

  AlarmManager manager = (AlarmManager) getSystemService(ALARM_SERVICE);

接下来,调用AlarmManager的set()方法就可以设置一个定时任务了,比如说想要设定一个任务在10秒以后执行,就可以写成:

long triggerAtTime=SystemClock.elapsedRealTime()+10*1000;

manager.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, triggerAtTime, pendingIntent);

set()方法中需要传入的三个参数稍微有点复杂

第一个参数是一个整型参数,用于指定AlarmManager 的工作类型,有四种值可选,分别是

ELAPSED_REALTIME、ELAPSED_REALTIME_WAKEUP、 RTC和 RTC_WAKEUP。

其中 ELAPSED_REALTIME 表示让定时任务的触发时间从系统开 机开始算起,但不会唤醒 CPU。

ELAPSED_REALTIME_WAKEUP同样表示让定时任务的触 发时间从系统开机开始算起,但会唤醒 CPU。

RTC表示让定时任务的触发时间从 1970年 1 月 1日 0点开始算起,但不会唤醒 CPU。

RTC_WAKEUP同样表示让定时任务的触发时间从 1970年 1月 1日 0点开始算起,但会唤醒 CPU。

使用 SystemClock.elapsedRealtime()方法可 以获取到系统开机至今所经历时间的毫秒数,使用

System.currentTimeMillis()方法可以获取 到 1970年 1月 1日 0点至今所经历时间的毫秒数。

第二个参数,就是定时任务触发的时间,以毫秒为单位。

如果第一个参数使用的是ELAPSED_REALTIME或ELAPSED_REALTIME_WAKEUP, 则这里传入开机至今的时间再加上延迟执行的时间。

如果第一个参数使用的是 RTC 或 RTC_WAKEUP,则这里传入 1970年 1月 1日 0点至今的时间再加上延迟执行的时间。

第三个参数是一个pendingIntent,对于它你应该已经不会陌生了吧。这里我们一般会调

getBroadcast()方法来获取一个能够执行广播的 PendingIntent。这样当定时任务被触发的时 候,广播接收

器的 onReceive()方法就可以得到执行。

首先,我们来创建一个长时间运行的服务,创建一个ServiceBestPractice项目,然后新增一个LongRunningService类,代码如下:

public class LongRunningService extends Service {
    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        new Thread(new Runnable() {
            @Override
            public void run() {
//                Toast.makeText(getApplication(), "定时任务开始", Toast.LENGTH_SHORT).show();
                Log.d("LongRunningService", "executed at " + new Date());
            }
        }).start();
        AlarmManager manager = (AlarmManager) getSystemService(ALARM_SERVICE);
        int anHour = 60 * 1000;//这是一分钟的毫秒数
        long triggerAtTime = SystemClock.elapsedRealtime() + anHour;
        Intent i = new Intent(this, AlarmReceiver.class);
        PendingIntent pi = PendingIntent.getBroadcast(this, 0, i, 0);
        manager.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, triggerAtTime, pi);
        return super.onStartCommand(intent, flags, startId);
    }
}

我们在onStartCommand()方法里开启了一个子线程,然后在子线程里就可以执行具体的逻辑操作了。

创建线程之后的代码就是我们刚刚讲解的 Alarm 机制的用法了,先是获取到了 AlarmManager的实例,然

后定义任务的触发时间为一小时后,再使用 PendingIntent指定处 理定时任务的广播接收器为

AlarmReceiver,最后调用 set()方法完成设定。 显然,AlarmReceiver目前还不存在呢,所以下一步就是要

新建一个 AlarmReceiver类, 并让它继承自 BroadcastReceiver,代码如下所示:

public class AlarmReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        Intent i = new Intent(context, LongRunningService.class);
        context.startService(i);
    }
}

onReceive()方法里的代码非常简单,就是构建出了一个 Intent 对象,然后去启动 LongRunningService这个服务。

那么这里为什么要这样写呢?其实在不知不觉中,这就已经 将一个长期在后台定时运行的服务完成了。因为

一旦启动 LongRunningService,就会在 onStartCommand()方法里设定一个定时任务,这样一小时后

AlarmReceiver的 onReceive()方 法就将得到执行,然后我们在这里再次启动 LongRunningService,这样

就形成了一个永久的 循环,保证 LongRunningService可以每隔一小时就会启动一次,一个长期在后台定时

运行的 服务自然也就完成了。 接下来的任务也很明确了,就是我们需要在打开程序的时候启动一次

LongRunningService, 之后 LongRunningService就可以一直运行了。

修改 MainActivity中的代码,如下所示:

public class AlarmActivity extends BaseActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Intent intent = new Intent(this, LongRunningService.class);
        startService(intent);
    }
}

最后别忘了,我们所用到的服务和广播接收器都要在 AndroidManifest.xml中注册才行。

0
0
查看评论

Linux_git定时更新代码脚本(crontab)

git 定时更新代码脚本
  • csdn_yasin
  • csdn_yasin
  • 2017-04-21 17:48
  • 1565

实现WEB站点的后台定时任务

1、为什么WEB站点要用后台定时任务 也许有人要问,WEB站点本身就后台服务了,为什么还要定制后台定时任务呢? 其实很简单,做过实际WEB应用的人都知道。一个实际站点内经常要做一些后台处理,如统计、评价、数据更新等操作,其中一些任务是非常有规律地重复,当然可以由管理员定期去执行我们开发好的WEB页上...
  • f9inux
  • f9inux
  • 2007-10-06 20:10
  • 4179

四大组件之——service应用实例一(在后台执行定时任务)

Service是android中实现程序后台运行的解决方案,适合于执行那些不需要和用户交互且要求长期执行的任务,Service有以下几个特点: 1.service运行在后台,前台看不到 2.service不是运行在一个独立的进程中的,而是依赖于创建服务时所在的应用程序进程,程序被杀掉时,服务也会停止...
  • huangyitingwoqu
  • huangyitingwoqu
  • 2015-06-11 20:45
  • 824

webcron 定时任务管理系统

webcron 一个定时任务管理器,基于Go语言和beego框架开发。用于统一管理项目中的定时任务,提供可视化配置界面、执行日志记录、邮件通知等功能,无需依赖*unix下的crontab服务。 项目背景 开发此项目是为了解决本人所在公司的PHP项目中定时任务繁多,使用crontab不好管理...
  • u010154380
  • u010154380
  • 2017-02-24 12:13
  • 2543

详解java定时任务

在我们编程过程中如果需要执行一些简单的定时任务,无须做复杂的控制,我们可以考虑使用JDK中的Timer定时任务来实现。下面LZ就其原理、实例以及Timer缺陷三个方面来解析java Timer定时器。一、简介      在java中一个完整定时任务需...
  • chenssy
  • chenssy
  • 2014-06-20 12:07
  • 70005

某定时任务系统的方案设计------软件系统设计能力很重要

来看这样一个问题:         某账号系统的账号都在unsigned int内, 也就是0-42亿左右。 在这42亿账号中, 有大约1亿账号是相对非常活跃的用户, 用户和用户之间可以建立好友关系(类似于微信那样的好友关系)。 现在要设计一个定时赠言系统, ...
  • stpeace
  • stpeace
  • 2017-03-25 11:42
  • 2846

Java—实现每天定时执行任务

1、定义TimerManager类import java.util.Calendar; import java.util.Date; import java.util.Timer; /** * java定时任务,每天定时执行任务 * @author Lee */ public...
  • hacker_Lees
  • hacker_Lees
  • 2017-08-14 18:59
  • 1064

java定时任务 每天定时执行任务

转载网址:http://www.open-open.com/lib/view/open1338175095183.html http://blog.163.com/lxy_rk/blog/static/875638052009872514986/ java定时任务,每天定时执行任务。...
  • liang0000zai
  • liang0000zai
  • 2015-04-23 19:38
  • 1085

Linux后台定时任务

最近在公司做的项目需要定期更新一些数据,用到linxhout
  • jj12345jj198999
  • jj12345jj198999
  • 2014-04-14 11:17
  • 1144

观察者模式(Observer)在Android中的应用:

1.概念:Android中主要是指当某些敏感性数据eg:数据库和控件 发生变化的时候,发消息给对这些敏感数据感兴趣者,也即观察者,然后观察者用自己的业务逻辑处理。 2.应用举例: 比如银行账户改变,将消息发给用户,用户收到消息处理此事件。针对以上情况,观察者设计模式如下: a. 模拟数据库,里面...
  • huang_xiao_yu
  • huang_xiao_yu
  • 2015-11-01 20:29
  • 400
    个人资料
    • 访问:102340次
    • 积分:1912
    • 等级:
    • 排名:千里之外
    • 原创:94篇
    • 转载:37篇
    • 译文:0篇
    • 评论:11条
    最新评论