博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AlarmManager的学习与实现
阅读量:2391 次
发布时间:2019-05-10

本文共 2805 字,大约阅读时间需要 9 分钟。

综述
   
这个类提供了一种使用系统提供的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来发出广播。

包含的常量如下图:

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

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

      第二步:修改布局文件添加两个按钮,文件内容如下:

       第四步:修改alarmManager.java文件,主要实现给两个按钮设置事件监听器,在其中主要实现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,还要再工程的AndroidManifest文件中进行声明。

      第六步:运行程序,如下图。

    

转载地址:http://cvqab.baihongyu.com/

你可能感兴趣的文章
GlusterFS常用命令小结
查看>>
GlusterFS分布式文件系统使用简介
查看>>
Use Docker Engine plugins
查看>>
Using Gluster for a Distributed Docker Storage Volume
查看>>
有容云老司机带路, 使用Docker实现丝般顺滑的持续集成
查看>>
如何让Ubuntu系统支持WebP图片格式
查看>>
变态的静态资源缓存与更新(超详细好文)
查看>>
关于lvs均衡负载socket服务的配置实现
查看>>
Qt学习旅程(1)
查看>>
[转]CentOS 5.4挂载可读写NTFS
查看>>
SmartChineseAnalyzer的对中文开源社区是一大贡献
查看>>
[转]Apache Mahout 简介
查看>>
[转]分布式key-value存储方案介绍:Cassandra,LightCloud,TokyoCabinet
查看>>
[转]HDFS+MapReduce+Hive+HBase十分钟快速入门
查看>>
stdlib中的xmalloc,xfree,xinit_mempool
查看>>
关于Java Advanced Imaging(JAI)的一点积累
查看>>
Spirit越狱iPhone/iPod touch/iPad 3.1.3/3.2固件(Windows)
查看>>
[转]Adobe发布Puppet Recipes for Hadoop
查看>>
[转]mysql里not in语句怎么写
查看>>
outlook 2010 突破附件大小限制
查看>>