综述

    这个类提供了一种使用系统提供的alarm服务。这个服务同意用户安排他们的应用程序在将来的某一个时间点执行。当设置的alarm响起,那么之前系统为这个alarm注冊的Intent就会自己主动的执行目标应用程序(假设此时应用程序还没有执行)。即使在系统处于休眠状态时(假设在此期间alarm响起,那么就会唤醒设备),系统注冊的alarm依然保持,可是当alarm被关闭或者是系统重新启动后,之前设置的alarm就会被清除。

    在alarm的接收者的onReceive()方法运行的过程中,Alarm Manager就会持有一个CPU的锁(wake lock),这样就行确保在处理alarm broadcast的操作运行完毕之前系统不会进入休眠状态。一旦onReceive()方法运行完毕后,Alarm Manager就会释放持有的锁。这意味着,在某些情况下,一旦你的onReceive(0方法运行完毕后,系统有可能马上进入休眠状态。假设你的alarm的接收者调用Context.startService()方法启动一个服务,那么系统还是有可能在启动这项服务之前就进入休眠状态。为了防址这样的情况发生,你的BroadcastReceiver和Service须要实现一个独立的wake
lock策略来确保系统在完毕启动这项服务之前一直处于执行状态。

    注意:Alarm Manager的意图是实现安排你的应用程序在某个特定的时刻执行,即使你的应用此刻并没有执行。对于一般的时间操作(比如:ticks、timeouts等等),使用Handler将会更加的简单和高效。

    你不应该直接实例化这个类,取而代之的是通过例如以下方式获取:

Context.getSystemService(Context.ALARM_SERVICE)

经常使用的方法例如以下:

set()方法是设置在某个时间运行,有三个參数:第一个是alarm的类型,主要有下面几种类型:

ELAPSED_REALTIME, ELAPSED_REALTIME_WAKEUP, RTC or RTC_WAKEUP,这个大家看文档就知道了。

第二个參数是:第二个是alarm触发的时间,这个值的设置和前面一个參数,也就是alarm的类型是有关的。

第三个參数是一个PendingIntent的对象,alarm通常是通过发出一个广播来实现的,所以应该定义一个PendingIntent来发出广播。

包括的常量例如以下图:

接下里我们就实现一个样例,通过一个button设置alarm,然后在设定的时间到后,就实现alarm的效果---显示一个toast,当然也能够通过一个button取消设置的闹钟。

第一步:新建一个project,命名为alarmManager;

第二步:改动布局文件加入两个button,文件内容例如以下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello" /> <Button
android:id="@+id/set"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/set"/> <Button
android:id="@+id/cancel"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/cancel"/> </LinearLayout>

第四步:改动alarmManager.java文件,主要实现给两个button设置事件监听器,在当中主要实现alarm的广播的功能,当然还须要设置广播接收器,代码例如以下:

public class AlarmManagerActivity extends Activity {
private Button setBtn, cancelBtn;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); setBtn = (Button)findViewById(R.id.set);
cancelBtn = (Button)findViewById(R.id.cancel); final AlarmManager am = (AlarmManager)this.getSystemService(ALARM_SERVICE); Intent intent = new Intent();
intent.setAction("com.maker.alarmManager.app.MY_ACTION");
intent.putExtra("msg", "闹钟事件发生了");
final PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
final long time = System.currentTimeMillis(); setBtn.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
// TODO Auto-generated method stub
am.setRepeating(AlarmManager.RTC_WAKEUP, time, 10*1000, pi);
}
}); cancelBtn.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
// TODO Auto-generated method stub
am.cancel(pi);
}
});
}
}

第五步:实现广播接收器,在这的代码就是闹钟事件发生后要实现的功能:显示一条toast,代码例如以下:

public class MyReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
String msg = intent.getStringExtra("msg");
Toast.makeText(context, msg, Toast.LENGTH_LONG).show();
}
}

注意:实现了广播接收器MyReceiver,还要再project的AndroidManifest文件里进行声明。

第六步:执行程序,例如以下图。

AlarmManager的学习与实现的更多相关文章

  1. 深入学习android之AlarmManager

    对应AlarmManage有一个AlarmManagerServie服务程 序,该服务程序才是正真提供闹铃服务的,它主要维护应用程序注册下来的各类闹铃并适时的设置即将触发的闹铃给闹铃设备(在系统中,l ...

  2. Android用AlarmManager实现后台任务-android学习之旅(63)

    因为Timer不能唤醒cpu,所以会在省电的原因下失效,所以需要唤醒cpu在后台稳定化的执行任务,AlarmManager能够唤醒cpu 这个例子讲解了如何通过Service来在后他每一个小时执行.特 ...

  3. android学习笔记--AlarmManager

    AlarmManager称呼为全局定时器,有的称呼为闹钟.其实它的作用和Timer有点相似. 都有两种相似的用法: (1)在指定时长后执行某项操作(2)周期性的执行某项操作 AlarmManager ...

  4. Android随笔之——闹钟制作铺垫之AlarmManager详解

    说实话,之前写的两篇博客Android广播机制Broadcast详解.Android时间.日期相关类和方法以及现在要写的,都算是为之后要写的闹钟应用做铺垫,有兴趣的话,大家可以去看看前两篇博客. 一. ...

  5. android AlarmManager 详解

    在开发互联网应用时候,我们常常要使用心跳来保证客户端与服务器的连接.怎么完成心跳很关键,在说道客户端心跳功能时,如果使用Timer或者专门开起一个线程来做心跳的工作,会浪费CPU工作时间,而且也会更多 ...

  6. Android C2DM学习 - 云端推送

    一.基础知识 当我们开发需要和服务器交互的应用程序时,基本上都需要获取服务器端的数据,比如<地震及时通>就需要及时获取服务器上最新的地震信息.要获取服务器上不定时更新的信息一般来说有两种方 ...

  7. android学习精要

    第1章 初识android1.1 android平台概述1.2 android平台体系1.2.1 linux kernel内核层1.2.2 系统运行库libraries和android runtime ...

  8. Mono For Android中AlarmManager的使用

    最近做了一个应用,要求如下: 程序运行之后的一段时间,分别触发3个不同的事件.当然很快就想到了Android中的AlarmManager和BroadcastReceiver.但是毕竟Mono环境和Ja ...

  9. android学习经常使用的数据文件夹

    android工程实践 1.仿360一键清理实现(一) "一键清理"是一个桌面图标,点击图标后,显示一个视图.进行清理动画.之后显示清理了几个进程,释放了多少M内存.点击" ...

随机推荐

  1. IdHttpServer实现webservice(130篇DataSnap文章)

    IdHttpServer实现webservice   朋友有个项目,通信协议使用HTTP,数据序列使用BIN(二进制).他不知道要选用何种技术方案. REST webservice是http+json ...

  2. eval 捕获dbi错误

    [root@dr-mysql01 ~]# cat t2.pl use DBI; my $dbUser='zabbix'; my $user="root"; my $passwd=& ...

  3. 双向DFS模板题

    B. Book of Evil time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...

  4. android图片压缩的3种方法实例

    android 图片压缩方法: 第一:质量压缩法: private Bitmap compressImage(Bitmap image) { ByteArrayOutputStream baos = ...

  5. webpack React+ES6

    webpack踩坑之路——构建基本的React+ES6项目   webpack是最近比较火的构建工具,搭配上同样比较火的ReacJS与ES6(ES2015)一定是现在很多潮流 programmer 的 ...

  6. 所有CM_消息的说明

    这些CM消息,居然在Delphi的帮助里是没有任何说明的,真是昏倒.意外在高手的书里找到了所有说明,说明如下: Message Constant Value Description cm_Base $ ...

  7. 深度RAMOS,把操作系统全部安装在内存上

     你看下深度RAMOS就知道了  RAMOS+音速启动+绿色软件+云端  很爽 http://www.shenduwin7.com/jiaocheng/52.html

  8. Delphi控件的停靠功能

    Delphi自带的许多控件都有停靠功能,而且操作非常简单,大可不必选用第三方控件.        基本上,要进行Dock操作至少需要两个组件,一个人被附着的Dock Site组件,另一个人附在Dock ...

  9. Mysql免安装版脚本

    使用Mysql过程中经常需要使用到免安装版本(绿色版)的Mysql,开始网上搜了一大堆,但还真是不怎么好用. 只好自己琢磨了一番,现在放出来和大家分享下: //安装启动服务 @ECHO OFF if  ...

  10. [置顶] EasyMock构建单元测试

    1. 背景 单元测试作为程序的基本保障.很多时候构建测试场景是一件令人头疼的事.因为之前的单元测试都是内部代码引用的,环境自给自足.开发到了一定程度,你不得不到开始调用外部的接口来完成你的功能.而外部 ...