综述

    这个类提供了一种使用系统提供的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. HTTPS的学习

    HTTPS的学习总结   HTTPS学习总结 简述 HTTPS对比HTTP就多了一个安全层SSL/TLS,具体就是验证服务端的证书和对内容进行加密. 先来看看HTTP和HTTPS的区别 我用AFN访问 ...

  2. uva 1374 快速幂计算

    #include <iostream> #include <cstdio> #include <cmath> #include <cstring> #i ...

  3. UVA 529 Addition Chains(迭代搜索)

      Addition Chains  An addition chain for n is an integer sequence  with the following four propertie ...

  4. SetBkMode可设置文字背景色:TRANSPARENT或OPAQUE

    感受一下区别: procedure TForm1.Timer2Timer(Sender: TObject); var cvs: TCanvas; Rect: TRect; Str: string; b ...

  5. Could not find or load main class

    Then add '.' to your $CLASSPATH with CLASSPATH=.:$CLASSPATH or as a paramater with java -classpath . ...

  6. oracle在desc表时,name 和type列不能格式化问题(占位过长)

    今天玩Oracle的时候,遇到一个让人很无语的问题,我desc表的时候,总是发现name列和type 列占位太多, 无法很直观明白的显示出来各个列值,就像下面的样子: 这样让人很不舒服,当然,一看到列 ...

  7. 彻底搞定c指针

    第一篇 变量的内存实质 一.先来理解C语言中变量的实质 要理解C指针,我认为一定要理解C中“变量”的存储实质,所以我就从“变量”这个东西开始讲起吧! 先来理解理解内存空间吧!请看下图: 内存地址→   ...

  8. 在VC++中启用内存泄露检测

    检测内存泄漏的主要工具是调试器和 CRT 调试堆函数.若要启用调试堆函数,请在程序中包括以下语句: #define CRTDBG_MAP_ALLOC#include <stdlib.h># ...

  9. 程序猿的量化交易之路(29)--Cointrader之Tick实体(16)

    转载需注明出处:http://blog.csdn.net/minimicall,http://cloudtrade.top Tick:什么是Tick,在交易平台中很常见,事实上就 单笔交易时某仅仅证券 ...

  10. delphi 使用superobject实现jsonrpc的http远程调用 good

    http://blog.csdn.net/earbao/article/details/46423167