`
20386053
  • 浏览: 462035 次
文章分类
社区版块
存档分类
最新评论

Android中如何做到Service被关闭后又自动启动

 
阅读更多

转载:GL(arui319)http://blog.csdn.net/arui319 http://blog.csdn.net/arui319/article/details/7040980

那如何做到启动一个Service,并且在用户关闭后能自动又启动了呢?

一般的,都会在上面说到的BroadcastReceiver的实现里面,监听手机启动完成后,启动一个Service,这是一般的做法。问题是,用户可以关闭掉该Service。那么怎样才能使它被关闭掉以后,再次启动呢?聪明的你一定立即就想到了,如果不直接启动Service,而是启动一个timmer,或者alarmManager,然后每隔一段时间去启动Service,就可以了

package com.arui.framework.android.daemonservice;  
  
import android.app.AlarmManager;  
import android.app.PendingIntent;  
import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
import android.os.SystemClock;  
  
public class BootBroadcast extends BroadcastReceiver {  
  
    @Override  
    public void onReceive(Context context, Intent mintent) {  
  
        if (Intent.ACTION_BOOT_COMPLETED.equals(mintent.getAction())) {  
            // 启动完成  
            Intent intent = new Intent(context, Alarmreceiver.class);  
            intent.setAction("arui.alarm.action");  
            PendingIntent sender = PendingIntent.getBroadcast(context, 0,  
                    intent, 0);  
            long firstime = SystemClock.elapsedRealtime();  
            AlarmManager am = (AlarmManager) context  
                    .getSystemService(Context.ALARM_SERVICE);  
  
            // 10秒一个周期,不停的发送广播  
            am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, firstime,  
                    10 * 1000, sender);  
        }  
  
    }  
}  
package com.arui.framework.android.daemonservice;  
  
import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
  
public class Alarmreceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
  
        if (intent.getAction().equals("arui.alarm.action")) {  
            Intent i = new Intent();  
            i.setClass(context, DaemonService.class);  
            // 启动service   
            // 多次调用startService并不会启动多个service 而是会多次调用onStart  
            context.startService(i);  
        }  
    }  
}  
package com.arui.framework.android.daemonservice;  
  
import android.app.Service;  
import android.content.Intent;  
import android.os.IBinder;  
import android.util.Log;  
  
public class DaemonService extends Service {  
  
    @Override  
    public IBinder onBind(Intent intent) {  
        return null;  
    }  
  
    @Override  
    public void onCreate() {  
        super.onCreate();  
        Log.v("=========", "***** DaemonService *****: onCreate");  
    }  
  
    @Override  
    public void onStart(Intent intent, int startId) {  
        Log.v("=========", "***** DaemonService *****: onStart");  
        // 这里可以做Service该做的事  
    }  
}  
<receiver   
    android:name=" com.arui.framework.android.daemonservice.BootBroadcast"  
    android:permission="android.permission.RECEIVE_BOOT_COMPLETED">  
    <intent-filter>  
        <action android:name="android.intent.action.BOOT_COMPLETED" />  
    </intent-filter>  
</receiver>  
<receiver   
    android:name=" com.arui.framework.android.daemonservice.Alarmreceiver" >  
    <intent-filter>  
        <action android:name="arui.alarm.action" />  
    </intent-filter>  
</receiver>  
      <service  
          android:name=" com.arui.framework.android.daemonservice.DaemonService" >  
      </service>  

备注一:这里面涉及的PendingIntent之前没有接触过
转载:http://www.devdiv.com/home.php?mod=space&uid=1&do=blog&id=2644

Intent比较简单,类似消息,发送给别的activity,别的activity会立即执行
我主要说说什么是PendingIntent以及它的执行过程
以alarm service为例:
1. activity请求一个alarm一般这样来做:
# //创建一个PendingIntent
# Intent intent = new Intent(ALARM_ALERT_ACTION);
# intent.putExtra(ID, id);
# intent.putExtra(TIME, atTimeInMillis);
# PendingIntent sender = PendingIntent.getBroadcast(
# context, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
# //获得AlarmMnager并注册一个新闹铃,
# //一次性闹铃的设置
#
# AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);
# am.set(AlarmManager.POWER_OFF_WAKEUP, atTimeInMillis, sender);
2. AlarmManager.set调用AlarmManagerService.set
3. AlarmManagerService.set的核心代码如下:

我们可以看到它就是把PendingIntent保存起来而已
4. alarm manager service会定时查看是否有alarm到期了,如果到期了做相应处理。
5. AlarmThread会调用
alarm.operation.send(mContext, 0,
mBackgroundIntent.putExtra(
Intent.EXTRA_ALARM_COUNT, alarm.count),
mResultReceiver, mHandler);
也就是通过PendingIntent.send执行intent操作,alarm这个就会发送ALARM_ALERT_ACTION的broadcast。

补充说明:
1. PendingIntent重要特点是异步处理。
2. 另外有一个要说明的是PendingIntent.onFinished,它可以作为PendingIntent.send的一个参数,
我们知道PendingIntent.send一般是在service中执行,这个调用的send后,回调onFished类的onSendFinished,所以onSendFinished一般也是在service中执行的


首先看官方解释:An Intent is something that is used right now; a PendingIntent is something that may create an Intent in the future. You will use a PendingIntent with Notifications, AlarmManager, etc.

PendingIntent就是一个Intent的描述,我们可以把这个描述交给别的程序,别的程序根据这个描述在后面的别的时间做你安排做的事情(By giving a PendingIntent to another application, you are granting it the right to perform the operation you have specified as if the other application was yourself,就相当于PendingIntent代表了Intent)


备注二:AlarmManager

转载:http://www.cnblogs.com/jico/archive/2010/11/03/1868361.html

AlarmManager的使用机制有的称呼为全局定时器,有的称呼为闹钟。通过对它的使用,个人觉得叫全局定时器比较合适,其实它的作用和Timer有点相似。都有两种相似的用法:(1)在指定时长后执行某项操作(2)周期性的执行某项操作

AlarmManager对象配合Intent使用,可以定时的开启一个Activity,发送一个BroadCast,或者开启一个Service.

下面的代码详细的介绍了两种定时方式的使用:

(1)在指定时长后执行某项操作

代码 

       //操作:发送一个广播,广播接收后Toast提示定时操作完成
Intent intent =new Intent(Main.this, alarmreceiver.class);
intent.setAction(
"short");
PendingIntent sender
=
PendingIntent.getBroadcast(Main.
this, 0, intent, 0);

//设定一个五秒后的时间
Calendar calendar=Calendar.getInstance();
calendar.setTimeInMillis(System.currentTimeMillis());
calendar.add(Calendar.SECOND,
5);

AlarmManager alarm
=(AlarmManager)getSystemService(ALARM_SERVICE);
alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), sender);
//或者以下面方式简化
//alarm.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+5*1000, sender);

Toast.makeText(Main.
this, "五秒后alarm开启", Toast.LENGTH_LONG).show();

//注意:receiver记得在manifest.xml注册

代码
public static class alarmreceiver extends BroadcastReceiver{

@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
if(intent.getAction().equals("short")){
Toast.makeText(context,
"short alarm", Toast.LENGTH_LONG).show();
}
else{
Toast.makeText(context,
"repeating alarm",
Toast.LENGTH_LONG).show();
}
}
}

(2)周期性的执行某项操作

代码
Intent intent =new Intent(Main.this, alarmreceiver.class);
intent.setAction(
"repeating");
PendingIntent sender
=PendingIntent
.getBroadcast(Main.
this, 0, intent, 0);
//开始时间
long firstime=SystemClock.elapsedRealtime();

AlarmManager am=(AlarmManager)getSystemService(ALARM_SERVICE);
  //5秒一个周期,不停的发送广播
am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP
, firstime,
5*1000, sender);

AlarmManager的setRepeating()相当于Timer的Schedule(task,delay,peroid);有点差异的地方时Timer这个方法是指定延迟多长时间

以后开始周期性的执行task;

AlarmManager的取消:(其中需要注意的是取消的Intent必须与启动Intent保持绝对一致才能支持取消AlarmManager)

代码
Intent intent =new Intent(Main.this, alarmreceiver.class);
intent.setAction(
"repeating");
PendingIntent sender
=PendingIntent
.getBroadcast(Main.
this, 0, intent, 0);
AlarmManager alarm
=(AlarmManager)getSystemService(ALARM_SERVICE);
alarm.cancel(sender);








分享到:
评论

相关推荐

    解析Android中如何做到Service被关闭后又自动启动的实现方法

    有的服务做的更绝,当用户在运行的服务中手动停止该服务以后,过了一段时间,服务又自动运行了。虽然,从用户的角度来说,这种方式比较流氓。但是,从程序员的角度来说,这是如何做到的呢?经过研究,我发现有一种...

    Service被关闭后又自动启动( Android平台).docx

    Service被关闭后又自动启动( Android平台).docx

    Service被关闭后又自动启动( Android平台).pdf

    Service被关闭后又自动启动( Android平台).pdf

    【Android studio】service在app直接退出下,整体输出情况,实现开机自启动,一直后台运行

    1. AIDL(Android Interface Definition Language):如果需要在应用退出后使Service持续运行,可以使用AIDL实现进程间通信(IPC),这样即使应用被关闭,Service所在的进程仍然可以运行。 2. 后台任务:使用...

    Android应用开机自动启动

    在Android系统中,应用通常不会在开机时自动启动,除非开发者特别设置了这个功能。这个功能在某些场景下非常有用,比如天气更新应用、消息推送服务等。本篇将详细讲解如何实现Android应用的开机自动启动。 一、...

    android service 简单实例源代码

    1. 使用`startService()`启动Service后,即使应用被关闭,Service仍然会运行,直到调用`stopService()`或`stopSelf()`。 2. 使用`bindService()`绑定Service时,Service会在客户端绑定后启动,客户端解绑后停止。 3....

    Android中Service的作用与定义.pdf

    在Android应用开发中,Service是不可或缺的一个核心组件,主要用于实现应用程序在后台长时间运行的任务,即使用户界面不再活跃或应用程序被关闭。Service不同于Activity,它不包含用户界面,但可以与其他组件(如...

    Service 启动与停止

    在Android应用开发中,理解Service的启动与停止机制对于创建高效、稳定的后台服务至关重要。 一、Service概述 Service是在Android应用程序中用于实现无界面、长时间运行任务的组件。它可以在用户界面关闭或者应用...

    Android停止Service的例程

    在Android应用开发中,Service是四大组件之一,用于在后台执行长时间运行的操作,即使用户离开了应用程序界面,Service依然可以运行。本教程将深入探讨如何正确地停止一个Android Service,同时结合源码分析其内部...

    android demo,Service服务在android中的应用源代码。

    Service是Android系统中的一种核心组件,它主要用于在后台执行长时间运行的任务,即使用户与应用程序的交互界面(Activity)已经关闭。这个"android demo,Service服务在android中的应用源代码"是一个示例,展示了...

    android 开机自启动+后台服务+自动关机

    2. **后台服务(Service)**:Android中的Service是一种可以在后台长时间运行的组件,即使用户界面被关闭,Service仍可继续执行任务。创建一个Service需要在代码中定义Service类并重写生命周期方法,如...

    android中service组件自我学习练习

    Service可以在用户界面关闭或者应用被切换到后台时仍然保持运行状态,这使得Service成为处理音乐播放、后台数据同步、定时任务等场景的理想选择。本练习主要涉及对Android Service的理解和实践。 首先,我们来深入...

    Android-AndroidService下载文件

    在Android应用开发中,`Service` 是一个非常重要的组件,它允许应用程序在后台长时间运行操作,即使用户已经离开或关闭了应用界面。本教程将详细讲解如何利用Android的`Service` 组件来实现文件下载功能。 一、...

    Android之Service实现比较大小

    在Android开发中,Service是应用程序组件之一,用于在后台执行长时间运行的操作,即使用户与应用程序交互的界面已关闭。本篇文章将深入探讨Android中的Service,分析不同类型的Service及其特性,并对比它们之间的...

    Android Service深入解析Demo

    这篇博客"Android Service深入解析Demo"通过实例深入讲解了Service的相关知识,下面将详细阐述Service的核心概念、生命周期、启动与绑定方式以及如何在实践中应用。 1. **Service核心概念** Service是Android系统...

    Android后台保持运行,开机后自动启动设定好的APK的DEMO.zip

    在Android平台上,实现应用在后台保持运行以及开机后自动启动是一项常见的需求,尤其对于服务类或者需要持续监控的软件来说。这个"Android后台保持运行,开机后自动启动设定好的APK的DEMO.zip"文件应该包含了一个...

    Android Service简单实例

    在Android应用开发中,Service是四大组件之一,用于在后台执行长时间运行的操作,即使用户界面关闭也能继续工作。本篇文章将深入探讨`startService`类型的Android Service,通过一个简单的实例来展示其工作原理和...

    安卓后台保活服务service,自动重启APP

    在标题“安卓后台保活服务service,自动重启APP”中,核心概念是“后台保活”和“自动重启”,这涉及到安卓应用如何在后台保持活动状态以及在被系统清理后如何重新启动。 首先,我们来理解“后台保活”。安卓系统...

    android动态设置开机自动启动程序

    在Android系统中,实现动态设置开机自动启动程序是一项常见的需求,尤其对于开发者和系统优化者来说,这有助于确保某些服务或应用在设备启动时能够自动运行。本文将深入探讨如何在Android平台上实现实现这一功能。 ...

Global site tag (gtag.js) - Google Analytics