Android后台Service已死 WorkManager崛起

后台服务已死

Service是可以在后台执行长时间运行的应用程序组件,它不提供用户界面。

Service分为前台服务和后台服务,我们这只讨论后台服务,所以后台服务的目的:
在后台执行长时间的任务。

从Android O之后的系统,安卓对服务的使用做了越来越多的限制。

安卓官网的说明:
https://developer.android.com/about/versions/oreo/background.html

在后台中运行的 Service 会消耗设备资源,这可能会降低用户体验。为了缓解这一问题,系统对这些 Service 施加了一些限制:

  • 在该时间窗结束后,应用将被视为处于空闲状态。 此时,系统将停止应用的后台 Service,就像应用已经调用 Service 的 Service.stopSelf() 方法一样。

也就是说,当你的应用不在前台,时间窗结束后,会变成闲置状态,系统就杀死你的后台服务。

网上一系列Service保活,创建永不停止Service,经过验证,都已失效。即你无法在使用后台服务在后台偷偷执行需要长时间的任务,例如监控GPS状态,记录步数等等。

这是Android系统的大势所趋,为什么安卓要限制服务的使用呢?

限制后台服务使用的原因是,当你的app使用服务在后台运行时,你的app消耗了宝贵的资源:

  • 内存
  • 电池

最佳的做法是:操作完成后,服务应自行停止。

但是,许多应用程序具有长时间运行的后台服务,这些服务基本上运行无限时间以维持与服务器的Socket连接或监视某些任务或用户活动。这些服务会导致电池耗尽,并且还会不断消耗内存。

鉴于以上原因:后台服务已经无法再在后台执行长时间任务。

所以,安卓退出了WorkManager完美解决了此类问题。

WorkManager崛起

WorkManager官网说明:
https://developer.android.com/reference/androidx/work/WorkManager

  • WorkManager是一个用于排队可延迟工作的库,保证在满足约束条件后的某个时间执行。 WorkManager允许观察工作状态和创建复杂工作链的能力。
  • WorkManager旨在通过为系统驱动的后台处理提供一流的API来简化开发人员体验。它适用于即使应用程序不再位于前台也应运行的后台作业。在可能的情况下,它使用JobScheduler或Firebase JobDispatcher来完成工作; 如果你的应用程序在前台,它甚至会尝试直接在你的过程中完成工作。

应用场景:每15分钟跟踪用户位置
创建一个SocketWorker.java

public class SocketWorker extends Worker {
    private static final String TAG = SocketWorker.class.getSimpleName();

    public SocketWorker(@NonNull Context context, @NonNull WorkerParameters workerParams) {
        super(context, workerParams);
    }

    @NonNull
    @Override
    public Result doWork() {
        Log.i(TAG,"doWork");
        return Result.success();
    }
}

启动:

PeriodicWorkRequest.Builder blurBuilder = new PeriodicWorkRequest.Builder(SocketWorker.class,PeriodicWorkRequest.MIN_PERIODIC_FLEX_MILLIS, TimeUnit.MILLISECONDS);
WorkManager.getInstance().enqueue(blurBuilder.build());

最小时间:

    /**
     * The minimum interval duration for {@link PeriodicWorkRequest} (in milliseconds).
     */
    public static final long MIN_PERIODIC_INTERVAL_MILLIS = 15 * 60 * 1000L; // 15 minutes.
    /**
     * The minimum flex duration for {@link PeriodicWorkRequest} (in milliseconds).
     */
    public static final long MIN_PERIODIC_FLEX_MILLIS = 5 * 60 * 1000L; // 5 minutes.
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sunxiaolin2016

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值