综述

    这个类提供了一种使用系统提供的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. JQuery 插件之Ajax Autocomplete(ajax自动完成)

    平时用百度,谷歌搜索的时候 会有一个下 拉列表进行提示 这是一个非常好的功能 本文要介绍的这个JQuery 插件 名叫Ajax Autocomplete 顾名思义 ajax 也就是用ajax的方式获取 ...

  2. MySQL installer

  3. Mysql找回管理员password

    我们使用MYSQL的时候有可能由于种种原因忘记ROOTpassword,假设是那样数据库可能就废掉了.可是今天给大家分享下找回ROOTpassword的方法或者说是在不知道rootpassword的情 ...

  4. win7+Powerpoint2007下设置演讲者视图,两步搞定

    步骤1: 步骤2: 这样,你就可以对着ppt的备注讲解了,且用户看不到你的备注以及你的电脑桌面.cool!

  5. Tomcat详细用法学习(一)

    在之前有关Tomcat的随笔<Tomcat免安装版的环境变量配置以及Eclipse下的Tomcat配置和测试>和<其他主机连接本地主机Tomcat会出现的防火墙问题>中已经详细 ...

  6. 基于Apriori算法的Nginx+Lua+ELK异常流量拦截方案 郑昀 基于杨海波的设计文档(转)

    郑昀 基于杨海波的设计文档 创建于2015/8/13 最后更新于2015/8/25 关键词:异常流量.rate limiting.Nginx.Apriori.频繁项集.先验算法.Lua.ELK 本文档 ...

  7. air ios 输入遮挡问题

    <!-- Adobe AIR Application Descriptor File Template. Specifies parameters for identifying, instal ...

  8. hibernate.cfg.xml文件的配置模板和不同数据库的配置參数

    (1)hibernate.cfg.xml文件的配置模板 <?xml version="1.0" encoding="UTF-8"?> <!DO ...

  9. 获取option中间的值

    <select name="wytype" id="wytype"> <option value="">—请选择—& ...

  10. java反射机制 + Method.invoke解释 getMethod + 反射理解

    功能: 通过读取另一个Dll去创建一个控件(Form,Button,TextBox,DataGridView),然后对当中一些属性进行检查. 创建控件的大致流程是,Assembly->Modul ...