Android 使用AlarmManager实现定时任务

1.工具类

public class AlarmManagerUtils {
    private Context context;
    private AlarmManager am;
    private PendingIntent pendingIntent;
    private Calendar calendar;

    private AlarmManagerUtils(Context aContext) {
        this.context = aContext;
    }

    private static AlarmManagerUtils instance = null;

    public static AlarmManagerUtils getInstance(Context aContext) {
        if (instance == null) {
            synchronized (AlarmManagerUtils.class) {
                if (instance == null) {
                    instance = new AlarmManagerUtils(aContext);
                }
            }
        }
        return instance;
    }

    public void createGetUpAlarmManager(int requestCode) {
        am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        Intent intent = new Intent(context, AlertService.class);
        //不同的任务requesCode需要定义成不同的,否则,后面的会把前面的任务给覆盖掉
        pendingIntent = PendingIntent.getService(context, requestCode, intent, 0);
    }

    @SuppressLint("NewApi")
    public void getUpAlarmManagerStartWork(int hour, int minute, int second) {
        calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY, hour);
        calendar.set(Calendar.MINUTE, minute);
        calendar.set(Calendar.SECOND, second);
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {// 6.0及以上
            am.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP,
                    calendar.getTimeInMillis(), pendingIntent);
        } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {// 4.4及以上
            am.setExact(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(),
                    pendingIntent);
        }
    }

    public void cancelAllAlarm() {
        if (null != am && null != pendingIntent) {
            try {
                am.cancel(pendingIntent);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

}

需要说明的部分:

pendingIntent = PendingIntent.getService(context, requestCode, intent, 0);

这里,requestCode需要保证唯一性,如果requestCode相同,那么新的定时会替换掉旧的,所以,如果想要同时实现定义多个定时器,那么这里requestCode一定要使用不同的值。因此,createGetUpAlarmManager 方法增加了requestCode的形参

2.定义服务,用于处理当定时完成时的处理逻辑(比如说,信息发布系统中的场景是,给那些目前还不到播放时间的节目,按照播放时间定义定时任务,例如当前9点,节目列表中有10点开始播和11点开始播的节目,那么我就需要增加10点和11点的定时任务,那么到了播放时间,就通知主线程开始新的播放)

public class AlertService extends Service {

    public AlertService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        // TODO: Return the communication channel to the service.
        throw new UnsupportedOperationException("Not yet implemented");

    }

    @RequiresApi(api = Build.VERSION_CODES.M)
    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
		//这里可以定时完成时的处理逻辑,我的处理是对外发送LiveDataBus通知。
		//如果说需要针对不同的定时执行不同的逻辑,则可以在定义pendingintent
		//时,在其中put便于处理逻辑的参数即可实现
        LiveDataBus.getInstance()
                .with(EventBus.ITS_TIME_TO_PLAY_THE_NEXT_PROGRAM, Object.class)
                .postValue(new Object());
        return super.onStartCommand(intent, flags, startId);
    }
}

service需要在配置文件中声明

AlarmManagerUtils.getInstance(this).cancelAllAlarm();
<service
            android:name=".service.AlertService"
            android:enabled="true"
            android:exported="true"></service>

3.具体调用

(1)创建定时

AlarmManagerUtils alarmManagerUtils = AlarmManagerUtils.getInstance(this);
                            alarmManagerUtils.createGetUpAlarmManager(i);
//该方法传入具体的定时的”时分秒”,比如这里定义12点整的定时                           alarmManagerUtils.getUpAlarmManagerStartWork(12,0,0);
 

(2)取消所有定时器:

AlarmManagerUtils.getInstance(this).cancelAllAlarm();

(3)增加对EventBus的处理(这一步是与我前面的业务相关,如果前面AlertService 中不是使用LiveDataBus通知的,则这一步也可以是其他的处理或者省略)

LiveDataBus.getInstance()
                .with(EventBus.ITS_TIME_TO_PLAY_THE_NEXT_PROGRAM, Object.class)
                .observe(this, event -> {
                    LogUtil.d("定时到了,开始播下一个节目");
                    playNextProgram();
                });

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使用 AlarmManager 实现定时重置流量统计可以分为以下几个步骤: 1. 在 AndroidManifest.xml 文件中添加以下权限: ```xml <uses-permission android:name="android.permission.MODIFY_PHONE_STATE" /> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> ``` 2. 创建一个 BroadcastReceiver,用于接收定时任务的触发事件,并在其中实现重置流量统计的逻辑。例如: ```java public class TrafficStatsResetReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // 重置流量统计信息 TrafficStats.clearAllStats(); } } ``` 3. 在 AndroidManifest.xml 文件中注册 BroadcastReceiver,并且添加一个 ACTION_BOOT_COMPLETED 的 intent-filter,以便在设备启动时启动定时任务。例如: ```xml <receiver android:name=".TrafficStatsResetReceiver" android:enabled="true" android:exported="false"> <intent-filter> <action android:name="com.example.trafficstatsreset.ACTION_RESET_TRAFFIC_STATS" /> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> ``` 4. 在应用程序启动时注册一个定时任务,例如: ```java private void registerTrafficStatsResetTask(Context context) { // 创建一个 PendingIntent,用于触发定时任务 Intent intent = new Intent(context, TrafficStatsResetReceiver.class); intent.setAction("com.example.trafficstatsreset.ACTION_RESET_TRAFFIC_STATS"); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT); // 获取 AlarmManager 实例 AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); // 计算定时任务的触发时间 long triggerTime = System.currentTimeMillis() + 24 * 60 * 60 * 1000; // 每天重置一次流量统计 // 注册定时任务 alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, triggerTime, 24 * 60 * 60 * 1000, pendingIntent); } ``` 在上述代码中,我们创建了一个 PendingIntent,并将其传递给 AlarmManager 的 setRepeating 方法,以便注册一个每天重置一次流量统计的定时任务。需要注意的是,我们设置的定时任务触发时间是当前时间加上一天的时间间隔,这样可以确保定时任务在第二天凌晨触发。 5. 在应用程序启动时调用 registerTrafficStatsResetTask 方法,注册定时任务即可: ```java @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 注册定时任务 registerTrafficStatsResetTask(this); } ``` 经过上述步骤,您就可以使用 AlarmManager实现定时重置流量统计的功能了。需要注意的是,使用 AlarmManager 时需要仔细管理定时任务的触发时间和间隔,以确保应用程序的稳定性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

RPG旅人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值