android服务保活

Android5.0 以后系统对 Native 进程等加强了管理,Native 拉活方式失效。系统在 Android5.0 以上版本提供了 JobScheduler 接口,系统会定时调用该进程以使应用进行一些逻辑操作。

方案适用范围

该方案主要适用于 Android5.0 以上版本手机。

该方案在 Android5.0 以上版本中不受 forcestop 影响,被强制停止的应用依然可以被拉活,在 Android5.0 以上版本拉活效果非常好。

仅在小米手机可能会出现有时无法拉活的问题。

方案实现

JobSchedulerService

package com.aoaoyi.service;

import android.annotation.TargetApi;
import android.app.job.JobParameters;
import android.app.job.JobService;
import android.content.Intent;
import android.os.Build;

/**
 * Created by xy on 2016/12/2.
 */

@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public class JobSchedulerService extends JobService{

    @Override
    public boolean onStartJob(JobParameters params) {
        startMainService();
        jobFinished(params, false);
        return false;
    }

    @Override
    public boolean onStopJob(JobParameters params) {
        startMainService();
        return false;
    }

    @Override
    public void onTaskRemoved(Intent rootIntent) {
        startMainService();
    }

    public void startMainService(){
        startService(MainService.getIntentAlarm(this));
    }
}

注册JobSchedulerService

 <service
 android:name="com.aoaoyi.service.JobSchedulerService"
 android:permission="android.permission.BIND_JOB_SERVICE"
 android:enabled="true"
 android:exported="true"
 android:process=":push"/>   

权限

MainService


package com.aoaoyi.service;

import android.app.AlarmManager;
import android.app.PendingIntent;
import android.app.Service;
import android.app.job.JobInfo;
import android.app.job.JobScheduler;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.os.Build;
import android.os.IBinder;

public class MainService extends Service {

    /**
     * 每10分钟检查一次链接状态,确保service不被杀掉
     */
    private static final int KEEP_ALIVE_INTERVAL = BuildConfig.DEBUG ? 1 * 60 * 1000 : 10 * 60 * 1000;

    /**
     * ACTION Start
     */
    private static final String ACTION_START = "MainService.Action.Start";
    /**
     * ACTION Alarm
     */
    private static final String ACTION_ALARM = "MainService.Action.Alarm";
    /**
     * ACTION end start
     */
    private static final String ACTION_END_START = "MainService.Action.EndStart";

    private boolean mIsAddAliveAlarm = false;

    public MainService() {

    }

    @Override
    public IBinder onBind(Intent intent) {

        return null;
    }

    @Override
    public void onCreate() {
        if (!mIsAddAliveAlarm){
            addAliveAlarm();
            mIsAddAliveAlarm = true;
        }
        super.onCreate();
    }

    @Override
    public int onStartCommand(Intent pIntent, int pFlags, int pStartId) {
        if (null != pIntent){
            switch (pIntent.getAction()){
                case ACTION_START:

                    break;
                case ACTION_ALARM:

                    break;
                case ACTION_END_START:

                    break;
            }
        }
        if (!mIsAddAliveAlarm){
            addAliveAlarm();
            mIsAddAliveAlarm = true;
        }
        return START_STICKY;
    }

    @Override
    public void onTaskRemoved(Intent pIntent) {
        onEnd();
    }

    @Override
    public void onDestroy() {
        onEnd();
        super.onDestroy();
    }

    private void onEnd() {
        startService(getIntentEndStart(getApplicationContext()));
    }


    /**
     * 添加重复唤醒闹钟,用于不停唤起服务
     */
    private void addAliveAlarm() {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            JobInfo.Builder _Builder = new JobInfo.Builder(0, new ComponentName(getApplication(), JobSchedulerService.class));
            _Builder.setPeriodic(KEEP_ALIVE_INTERVAL);
            _Builder.setPersisted(true);
            JobScheduler _JobScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
            _JobScheduler.schedule(_Builder.build());
        }else {
            PendingIntent _PendingIntent = PendingIntent.getService(this, 0, getIntentAlarm(this), PendingIntent.FLAG_UPDATE_CURRENT);
            AlarmManager _AlarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
            _AlarmManager.cancel(_PendingIntent);
            _AlarmManager.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + KEEP_ALIVE_INTERVAL, KEEP_ALIVE_INTERVAL, _PendingIntent);
        }
    }

    /**
     * Start
     *
     * @param pContext
     */
    public static Intent getIntentStart(Context pContext) {
        return getActionIntent(pContext, ACTION_START);
    }

    /**
     * Alarm
     *
     * @param pContext
     */
    public static Intent getIntentAlarm(Context pContext) {
        return getActionIntent(pContext, ACTION_ALARM);
    }

    /**
     * EndStart
     *
     * @param pContext
     */
    public static Intent getIntentEndStart(Context pContext) {
        return getActionIntent(pContext, ACTION_END_START);
    }

    /**
     * Service Intent
     *
     * @param pContext
     * @param pAction
     * @return
     */
    private static Intent getActionIntent(Context pContext, String pAction) {
        Intent _Intent = new Intent(pContext, MainService.class);
        _Intent.setAction(pAction);
        return _Intent;
    }

}

最后一步,在主Activity启动一次MainService

startService(MainService.getIntentStart(this));
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Studio是一款用于开发Android应用程序的集成发环境(IDE)。保活是指在Android应用程序在后台运行时,通过一些手段保持应用程序的运行状态,以避免被系统或其他因素终止。下面是一些常见的Android Studio保活方法: 1. 前台服务(Foreground Service):通过将服务设置为前台服务,可以提高服务的优先级,使其在后台运行时不容易被系统杀死。可以通过调用startForeground()方法将服务设置为前台服务,并在通知栏显示一个持续的通知来提醒用户。 2. JobScheduler:JobScheduler是Android提供的一种调度任务的机制,可以用于执行一些延迟或定时的任务。通过使用JobScheduler,可以在特定条件下触发任务的执行,从而保持应用程序的运行状态。 3. AlarmManager:AlarmManager是Android提供的一种定时任务调度器,可以用于在指定的时间触发某个操作。通过使用AlarmManager,可以定时启动一个服务或广播接收器,从而保持应用程序的运行状态。 4. 后台限制适配:Android系统对后台应用程序进行了一些限制,以减少资源消耗和提高系统性能。为了适应这些限制,可以通过使用WorkManager、JobIntentService等组件来执行后台任务,并避免直接在后台进行耗时操作。 5. 进程保活:可以通过将应用程序的进程设置为前台进程或使用一些第三方库来保持应用程序的进程不被系统杀死。但需要注意,过度使用进程保活可能会导致系统资源浪费和电池消耗增加。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值