安卓手机APP开发____持久性工作

2024-06-01 23:52

本文主要是介绍安卓手机APP开发____持久性工作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安卓手机APP开发____持久性工作

概述

如果工作始终要通过应用重启和系统重新启动来调度,便是持久性的工作。
WorkManager 是适用于持久性工作的推荐解决方案。 由于大多数后台处
理操作都是通过持久性工作完成的,因此 WorkManager 通常也是后台处理
的主要推荐 API。

持久性工作的类型

WorkManager 可处理三种类型的持久性工作:

    立即执行:必须立即开始且很快就完成的任务,可以加急。
    长时间运行的任务:运行时间可能较长(可能超过 10 分钟)的任务。
    可延期执行:延期开始并且可以定期运行的预定任务。


持久性工作可以是立即执行、长时间运行或可延期执行的工作


同样,下表大致列出了各种工作类型。
类型     周期     查找方式
即时     一次     OneTimeWorkRequest 和 Worker。如需加急工作,
请对 OneTimeWorkRequest 调用 setExpedited()。
长跑     一次性或定期     任意 WorkRequest 或 Worker。在 worker
中调用 setForeground() 来处理通知。
可延期     一次性或定期     天气Worker,温度为 PeriodicWorkRequest。

如需详细了解如何设置 WorkManager,请参阅定义您的 WorkRequest 指南。


WorkManager 功能

除了具备更为简单且一致的 API 之外,WorkManager 还具备许多其他关键优势:


工作约束

使用工作约束明确定义工作运行的最佳条件。例如,仅在设备采用不按流量
计费的网络连接时、当设备处于空闲状态或者有足够的电量时运行。

强大的调度

WorkManager 允许您使用灵活的调度窗口调度工作,以运行一次性或重复工作。
您还可以对工作进行标记或命名,以便调度唯一的、可替换的工作以及监控或
取消工作组。

已调度的工作存储在内部托管的 SQLite 数据库中,由 WorkManager 负责确保
该工作持续进行,并在设备重新启动后重新调度。

此外,WorkManager 遵循低电耗模式等省电功能和最佳做法,因此您在这方面无需担心。


加急工作

您可以使用 WorkManager 调度需在后台立即执行的工作。您应该使用加急工作来处
理对用户来说很重要且会在几分钟内完成的任务。

灵活的重试政策

有时工作会失败。WorkManager 提供了灵活的重试政策,包括可配置的指数退避政策。


工作链

对于复杂的相关工作,您可以使用直观的接口将各个工作任务串联起来,这样您
便可以控制哪些部分依序运行,哪些部分并行运行。
Kotlin
 


val continuation = WorkManager.getInstance(context).beginUniqueWork(Constants.IMAGE_MANIPULATION_WORK_NAME,ExistingWorkPolicy.REPLACE,OneTimeWorkRequest.from(CleanupWorker::class.java)).then(OneTimeWorkRequest.from(WaterColorFilterWorker::class.java)).then(OneTimeWorkRequest.from(GrayScaleFilterWorker::class.java)).then(OneTimeWorkRequest.from(BlurEffectFilterWorker::class.java)).then(if (save) {workRequest<SaveImageToGalleryWorker>(tag = Constants.TAG_OUTPUT)} else /* upload */ {workRequest<UploadWorker>(tag = Constants.TAG_OUTPUT)})

对于每项工作任务,您可以定义工作的输入和输出数据。将工作串联在一起时,
WorkManager 会自动将输出数据从一个工作任务传递给下一个工作任务。

内置线程互操作性

WorkManager 无缝集成 Coroutines 和 RxJava,让您可以插入自己
的异步 API,非常灵活。

注意:尽管 Coroutines 和 WorkManager 分别是针对于不同用例推荐
的解决方案,但它们二者并不是互斥的关系。您可以在通过 WorkManager
调度的工作中使用协程。

使用 WorkManager 保证工作可靠性

WorkManager 适用于需要可靠运行的工作,即使用户导航离开屏幕、退出应用
或重启设备也不影响工作的执行。例如:

    向后端服务发送日志或分析数据。
    定期将应用数据与服务器同步。

WorkManager 不适用于那些可在应用进程结束时安全终止的进程内后台工作。
它也并非对所有需要立即执行的工作都适用的通用解决方案。请查看后台处
理指南,了解哪种解决方案符合您的需求。

这篇关于安卓手机APP开发____持久性工作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022459

相关文章

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1