WorkManager
| Letzte Aktualisierung | Stabile Version | Releasekandidat | Betarelease | Alpha-Release | 
|---|---|---|---|---|
| 22. Oktober 2025 | 2.11.0 | - | - | - | 
Abhängigkeiten deklarieren
Wenn Sie eine Abhängigkeit von WorkManager hinzufügen möchten, müssen Sie Ihrem Projekt das Google Maven-Repository hinzufügen:
Fügen Sie der Datei build.gradle für Ihre App oder Ihr Modul die Abhängigkeiten für die benötigten Artefakte hinzu:
Cool
dependencies { def work_version = "2.11.0" // (Java only) implementation "androidx.work:work-runtime:$work_version" // Kotlin + coroutines implementation "androidx.work:work-runtime-ktx:$work_version" // optional - RxJava2 support implementation "androidx.work:work-rxjava2:$work_version" // optional - GCMNetworkManager support implementation "androidx.work:work-gcm:$work_version" // optional - Test helpers androidTestImplementation "androidx.work:work-testing:$work_version" // optional - Multiprocess support implementation "androidx.work:work-multiprocess:$work_version" }
Kotlin
dependencies { val work_version = "2.11.0" // (Java only) implementation("androidx.work:work-runtime:$work_version") // Kotlin + coroutines implementation("androidx.work:work-runtime-ktx:$work_version") // optional - RxJava2 support implementation("androidx.work:work-rxjava2:$work_version") // optional - GCMNetworkManager support implementation("androidx.work:work-gcm:$work_version") // optional - Test helpers androidTestImplementation("androidx.work:work-testing:$work_version") // optional - Multiprocess support implementation("androidx.work:work-multiprocess:$work_version") }
Informationen zur Verwendung von Kotlin-Erweiterungen finden Sie in der KTX-Dokumentation.
Weitere Informationen zu Abhängigkeiten finden Sie unter Build-Abhängigkeiten hinzufügen.
Feedback
Ihr Feedback hilft uns, Jetpack zu verbessern. Lassen Sie es uns wissen, wenn Sie neue Probleme entdecken oder Ideen zur Verbesserung dieser Bibliothek haben. Sehen Sie sich die vorhandenen Probleme in dieser Bibliothek an, bevor Sie ein neues erstellen. Sie können für ein vorhandenes Problem stimmen, indem Sie auf die Schaltfläche mit dem Stern klicken.
Weitere Informationen finden Sie in der Dokumentation zum Issue Tracker.
Version 2.11
Version 2.11.0
22. Oktober 2025
androidx.work:work-*:2.11.0 ist veröffentlicht. Version 2.11.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.10.0:
- Das minSdkwurde von API 21 auf API 23 aktualisiert.
- Die API setRemoteSessionTimeoutMillisim Konfigurationsgenerator vonWorkManagerwurde hinzugefügt, um die Konfiguration der Zeitspanne zu ermöglichen, in der eineRemoteWorkManager-Sitzung nach der letzten Verwendung aktiv ist.
Version 2.11.0-rc01
8. Oktober 2025
androidx.work:work-*:2.11.0-rc01 ist veröffentlicht. Version 2.11.0-rc01 enthält diese Commits.
Version 2.11.0-beta01
24. September 2025
androidx.work:work-*:2.11.0-beta01 ist veröffentlicht. Version 2.11.0-beta01 enthält diese Commits.
API-Änderungen
- Fügen Sie stopRunningWorkWithReasonzuWorkManagerTestDriverhinzu. (Ie53b2, b/439955564)
Fehlerkorrekturen
- Behebung des Problems, dass der Dienst im Vordergrund beendet wird, wenn ausstehende Befehle vorhanden sind (Iae822, b/432069314)
- Fehler behoben: Remote-Coroutine-Worker kann Remote-Dienst nicht entbinden (I842f2, b/247113322)
Version 2.11.0-alpha01
27. August 2025
androidx.work:work-*:2.11.0-alpha01 ist veröffentlicht. Version 2.11.0-alpha01 enthält diese Commits.
API-Änderungen
- Das minSdk wurde von API 21 auf API 23 aktualisiert (Ibdfca, b/380448311, b/435705964, b/435705223).
- Die API setRemoteSessionTimeoutMilliswurde dem Konfigurations-Builder von WorkManager hinzugefügt, um die Konfiguration der Zeitspanne zu ermöglichen, in der eine RemoteWorkManager-Sitzung nach der letzten Verwendung aktiv ist. (Ib23c8)
- Fügen Sie in WorkRequest.Buildereine experimentelle API hinzu, um Backoff anzuwenden, wenn die Arbeit vom System unterbrochen wird. (Ie2dc7, b/335513480)
- Test-API hinzugefügt, um eine andere Worker-Klasse an TestListenableWorkerBuilderzu übergeben als die, die erstellt wird, um benutzerdefinierteWorkerFactory-Implementierungen zu unterstützen (If6bff, b/389154854)
Fehlerkorrekturen
- Netzwerkfunktionen in SharedNetworkCallbackim Cache speichern, um unnötige IPCs zu vermeiden (Ie4027, b/427115602)
- Problem mit der Auswertung von Netzwerkbeschränkungen behoben, bei dem Arbeitsvorgänge nach dem ersten nicht die aktuellen Netzwerkfunktionen erhielten und stattdessen nach einem Zeitlimit ConstraintsNotMeterreichten (Ib6a66, b/427115602)
Version 2.10
Version 2.10.5
24. September 2025
androidx.work:work-*:2.10.5 ist veröffentlicht. Version 2.10.5 enthält diese Commits.
Fehlerkorrekturen
- Problem behoben, bei dem der Dienst im Vordergrund beendet wurde, wenn ausstehende Befehle vorhanden waren (Iae822, b/432069314)
Version 2.10.4
10. September 2025
androidx.work:work-*:2.10.4 ist veröffentlicht. Version 2.10.4 enthält diese Commits.
Fehlerkorrekturen
- Problem behoben: RemoteCoroutineWorkerkann den Remote-Dienst nicht entbinden (I842f2, b/247113322)
Version 2.10.3
30. Juli 2025
androidx.work:work-*:2.10.3 ist veröffentlicht. Version 2.10.3 enthält diese Commits.
Fehlerkorrekturen
- Ein Problem wurde behoben, bei dem Worker mit identischen Netzwerkbeschränkungen wie ein vorheriger Worker meldeten, dass ihre Beschränkungen nicht erfüllt wurden. (b/427115602).
Version 2.10.2
18. Juni 2025
androidx.work:work-*:2.10.2 ist veröffentlicht. Version 2.10.2 enthält diese Commits.
Fehlerkorrekturen
- Ein Problem wurde behoben, bei dem die Persistierung von Workern mit Netzwerkanfragen und Standardfunktionen dazu führte, dass entfernte Funktionen wieder hinzugefügt wurden. Dies führte zu einem fehlerhaften Verhalten von Workern mit Netzwerkbeschränkungen. (b/409716532)
- Ein Fehler wurde behoben, der dazu führte, dass Worker mit Netzwerkbeschränkungen nicht sofort ausgeführt wurden, weil die Beschränkungen nicht erfüllt waren, obwohl das Netzwerk und die Funktionen verfügbar waren. (b/423403088)
Version 2.10.1
23. April 2025
androidx.work:work-*:2.10.1 ist veröffentlicht. Version 2.10.1 enthält diese Commits.
Fehlerkorrekturen
- Die Wahrscheinlichkeit, dass TooManyRequestsExceptionvon der Registrierung vonWorkManagerfür einNetworkCallback, das für die Einschränkungsverfolgung verwendet wird, ausgelöst wird, wird verringert. (b/231499040, b309d5).
Version 2.10.0
30. Oktober 2024
androidx.work:work-*:2.10.0 ist veröffentlicht. Version 2.10.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.9.1
- Jobs wurden Trace-Tags aus WorkManagerhinzugefügt. Dadurch ist „adb shell dumpsys jobscheduler“ viel einfacher zu verstehen, da der Name des ausgeführten Worker enthalten ist. Außerdem werden Trace-Abschnitte um wichtige Bereiche vonWorkManagerherum hinzugefügt.
- Configuration.workerCoroutineContextwurde hinzugefügt, um den Dispatcher zu steuern, in dem- CoroutineWorkerausgeführt wird.
- Entwickler können NetworkRequestals Einschränkung für einen Worker über die MethodeConstraints.setRequiredNetworkRequestangeben. So können Sie genauer festlegen, in welchem Netzwerk dieser Worker ausgeführt werden soll.
- WorkManager2.10.0 wird jetzt mit SDK 35 kompiliert und enthält verschiedene Änderungen zur Kompatibilität mit SDK 35.
Version 2.10.0-rc01
24. Oktober 2024
androidx.work:work-*:2.10.0-rc01 ist veröffentlicht. Version 2.10.0-rc01 enthält diese Commits.
Version 2.10.0-beta01
2. Oktober 2024
androidx.work:work-*:2.10.0-beta01 ist veröffentlicht. Version 2.10.0-beta01 enthält diese Commits.
Version 2.10.0-alpha04
18. September 2024
androidx.work:work-*:2.10.0-alpha04 ist veröffentlicht. Version 2.10.0-alpha04 enthält diese Commits.
API-Änderungen
- Fügen Sie den Stoppgrund STOP_REASON_FOREGROUND_SERVICE_TIMEOUThinzu, wenn ein Worker im Vordergrund aufgrund eines Ausführungstimeouts basierend auf dem Typ des Dienstes im Vordergrund beendet wird. (Ibd0af)
Version 2.10.0-alpha03
4. September 2024
androidx.work:work-*:2.10.0-alpha03 ist veröffentlicht. Version 2.10.0-alpha03 enthält diese Commits.
Neue Funktionen
- Jobs wurden Trace-Tags aus WorkManagerhinzugefügt. Dadurch ist „adb shell dumpsys jobscheduler“ viel einfacher zu verstehen, da der Name des ausgeführten Worker enthalten ist. Außerdem werden Trace-Abschnitte um wichtige Bereiche vonWorkManagerherum hinzugefügt.
API-Änderungen
- WorkManager 2.10.0 wird jetzt mit SDK 35 kompiliert.
- Wir haben das Problem behoben, dass Vordergrund-Worker vom Typ „short service“ und „data sync“ ein Zeitlimit überschritten und einen ANR-Fehler verursacht haben, wenn WorkManagernichtstopSelf()aufgerufen hat. Dieser Fix gilt nur für Geräte mit API 34 und 35, auf denen Typen von Diensten im Vordergrund eingeführt wurden. (ca06b2, b/364508145)
- Neue WorkerParametersAPIs, mit denen der Remote-Prozess gewechselt werden kann, an den dieWorkergebunden wird, wenn eineWorkerFactoryverwendet wird. (Ibdc8a, Ie8a90, I7373f)
Fehlerkorrekturen
- Ein Absturz wurde behoben, der dadurch verursacht wurde, dass WorkManagerversucht hat, einen Worker mit langer Laufzeit (d.h. einen Worker im Vordergrund) neu zu starten, wenn für den Vordergrundtyp der Arbeit erforderliche Berechtigungen für Android 14 widerrufen wurden. (b/333957914)
- Die manuelle Beschreibung des Zugriffs auf neue Plattform-APIs wurde entfernt, da dies automatisch über die API-Modellierung erfolgt, wenn R8 mit AGP 7.3 oder höher verwendet wird (z. B. R8-Version 3.3), und für alle Builds, wenn AGP 8.1 oder höher verwendet wird (z. B. D8-Version 8.1). Clients, die AGP nicht verwenden, wird empfohlen, auf D8-Version 8.1 oder höher zu aktualisieren. Weitere Details findest du in diesem Artikel. (Ia60e0, b/345472586)
Version 2.10.0-alpha02
17. April 2024
androidx.work:work-*:2.10.0-alpha02 ist veröffentlicht. Version 2.10.0-alpha02 enthält diese Commits.
API-Änderungen
- Es wurde die Möglichkeit hinzugefügt, Trace-Spans über ein konfigurierbares @RestrictToTracerinWorkManagerauszugeben. (I17d7f, b/260214125)
- Configuration.workerCoroutineContextwurde hinzugefügt, um den Dispatcher zu steuern, in dem- CoroutineWorkerausgeführt wird. So lässt sich die Verwendung von- Dispatchers.Defaultin- WorkManagervollständig vermeiden. (Icd1b7)
- Benutzerdefinierte Ausnahmehandler für Workers hinzufügen (Ib1b74, b/261190695)
- OneTimeWorkRequest.Builderund- PeriodicWorkRequest.Builderkönnen jetzt mit- KClassanstelle von- Classerstellt werden:- val request = OneTimeWorkRequest.Builder(Worker::class).setConstraints(...).build()(Ib55f6)
- Die Klasse WorkManagerwurde zu Kotlin migriert. Methoden, dieLiveData,ListenableFutureoderFlowzurückgeben, liefern jetzt korrekte Informationen zur Nullable-Eigenschaft. Dazu sind möglicherweise Änderungen am Quellcode der Clients erforderlich, wenn die Annahmen zur Nullable-Eigenschaft in diesem Code falsch waren. (If6757)
Version 2.10.0-alpha01
24. Januar 2024
androidx.work:work-*:2.10.0-alpha01 ist veröffentlicht. Version 2.10.0-alpha01 enthält diese Commits.
Neue Funktionen
- Entwickler können NetworkRequestals Einschränkung für einen Worker über die MethodeConstraints.setRequiredNetworkRequestangeben. So können Sie genauer festlegen, in welchem Netzwerk dieser Worker ausgeführt werden soll.
API-Änderungen
- Es wurde die Möglichkeit hinzugefügt, NetworkRequestals Einschränkung anzugeben. (Id98a1, b/280634452)
Version 2.9
Version 2.9.1
7. August 2024
androidx.work:work-*:2.9.1 ist veröffentlicht. Version 2.9.1 enthält diese Commits.
Fehlerkorrekturen
- Ein Absturz wurde behoben, der dadurch verursacht wurde, dass WorkManagerversucht hat, einen Worker mit langer Laufzeit (d.h. einen Worker im Vordergrund) neu zu starten, wenn der Vordergrundtyp der Arbeit Berechtigungen für Android 14 hatte, die widerrufen wurden. (b/333957914)
Version 2.9.0
29. November 2023
androidx.work:work-*:2.9.0 ist veröffentlicht. Version 2.9.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.8.0
- Beobachtbarkeit über Flow. Anstelle vonLiveDatakann der Fortschritt des Workers jetzt über den Flow mitWorkManager.getWorkInfosFlowund ähnlichen Methoden beobachtet werden.
- WorkManagergibt jetzt einen Hinweis darauf, warum ein Worker zuvor angehalten wurde. Sie kann über die Methode- getStopReason()von einem Worker selbst oder über- getStopReason()von- WorkInfoabgefragt werden.
- Genaue Planung von periodischen Workern über setNextScheduleTimeOverride. So kann der nächste periodische Arbeitsplan dynamisch berechnet werden. Das kann verwendet werden, um erweiterte Funktionen wie adaptive Aktualisierungszeiten, benutzerdefiniertes Wiederholungsverhalten oder das Ausführen eines Newsfeed-Workers jeden Morgen vor dem Aufwachen des Nutzers ohne Drift zu implementieren.ExistingPeriodicWorkPolicy.UPDATEsollte in Kombination mit diesen Techniken verwendet werden, um zu vermeiden, dass ein aktuell ausgeführter Worker abgebrochen wird, während der nächste geplant wird.
- WorkManager-Tests mit Threads, die der Produktion entsprechen. ExecutorsMode.PRESERVE_EXECUTORSkann ininitializeTestWorkManagerverwendet werden, um inConfigurationfestgelegte Executors beizubehalten und den echten Hauptthread zu verwenden.
- Die Coroutines-APIs wie CoroutineWorkerwurden vom zusätzlichen Artefakt work-runtime-ktx zum Hauptartefakt work-runtime verschoben. work-runtime-ktx ist jetzt leer.
API-Änderungen
- stopReasonwurde- WorkInfohinzugefügt. Dadurch ist- stopReasonnach der Ausführung des Workers verfügbar. Das kann bei der Berichterstellung- stopReasonhilfreich sein, da eine App nach dem Beenden eines Workers sehr schnell beendet werden kann. (I21386)
- Zulassen, dass Clocküber die Konfiguration festgelegt und zur Steuerung der Ausführungsreihenfolge von Worker-Tests verwendet wird. (Ic586e)
- Der getStopReason()-Methode wurdeListenableWorkerhinzugefügt, um einen Hinweis darauf zu geben, warum der Worker angehalten wurde. (I07060)
- WorkManagerTestInitHelper#closeWorkDatabase()wurde hinzugefügt, um die Closeguard-Warnung zu Leaks von Ressourcen zu vermeiden. (Ia8d49)
- Der Konstruktor von WorkInfoist jetzt öffentlich, was beim Testen nützlich sein kann. (Ia00b6, b/209145335)
- work-runtime-ktxist jetzt leer.- CoroutineWorkerund andere Kotlin-spezifische Dienstprogramme sind jetzt im Hauptartefakt für die Laufzeit des Work Managers verfügbar. (I71a9a)
- Die Methode setNextScheduleTimeOverridewurde hinzugefügt, mit der sich periodische Arbeitspläne genau festlegen lassen (I3b4da).
- getNextScheduleTimeMilliswurde hinzugefügt, um Informationen zur geplanten Laufzeit abzurufen.- WorkInfo(I797e4)
- WorkInfowerden Informationen zur anfänglichen Verzögerung und zur Periodizität hinzugefügt. (I52f2f)
- Methoden zum Beobachten von Workern über Flows über die Methoden getWorkInfosByTagFlow,getWorkInfoByIdFlow,getWorkInfosForUniqueWorkFlow,getWorkInfosFlowhinzugefügt (If122a)
- Fehlende @RequiresApi(...)-Anmerkungen wurden den Konstruktoren und Properties vonConstraintshinzugefügt. Sie sind jetzt an entsprechende Anmerkungen zu Settern inConstraints.Builderangeglichen, die seit frühen Versionen vonWorkManagervorhanden sind. (I6d7d2)
- WorkManagerhat jetzt ein separates Limit für Content-URI-Worker, um ihnen garantierte Slots in- JobSchedulerzu geben und fehlende Inhaltsaktualisierungen bei hoher Last zu verhindern. Das Limit kann über- Configuration.Builder.setContentUriTriggerWorkersLimitkonfiguriert werden. (Ic128f)
- WorkInfowerden Einschränkungen hinzugefügt. (I162c0)
Version 2.9.0-rc01
18. Oktober 2023
androidx.work:work-*:2.9.0-rc01 ist veröffentlicht. Version 2.9.0-rc01 enthält diese Commits.
- Keine Änderungen seit der letzten Betaversion
Version 2.9.0-beta01
6. September 2023
androidx.work:work-*:2.9.0-beta01 ist veröffentlicht. Version 2.9.0-beta01 enthält diese Commits.
API-Änderungen
- Konstanten für die von WorkInfo.stopReasonundListenableWorker.stopReasonzurückgegebenen Gründe für das Beenden hinzugefügt (I0cc00)
Version 2.9.0-alpha02
26. Juli 2023
androidx.work:work-*:2.9.0-alpha02 ist veröffentlicht. Version 2.9.0-alpha02 enthält diese Commits.
Neue Funktionen
- WorkManagergibt jetzt einen Hinweis darauf, warum ein Worker zuvor angehalten wurde. Sie kann über die Methode- getStopReason()von einem Worker selbst oder über- getStopReason()von- WorkInfoabgefragt werden.
API-Änderungen
- stopReasonwurde- WorkInfohinzugefügt. Dadurch wird- stopReasonnach der Ausführung des Workers verfügbar. Das könnte bei der Berichterstellung- stopReasonhilfreich sein, da eine App selbst sehr schnell beendet werden kann, sobald ein Worker beendet wurde. (I21386)
- Die Uhr kann über die Konfiguration eingestellt und zur Steuerung der Ausführungsreihenfolge von Worker-Tests verwendet werden. (Ic586e)
- Der getStopReason()-Methode wurdeListenableWorkerhinzugefügt, um einen Hinweis darauf zu geben, warum der Worker angehalten wurde. (I07060)
- WorkManagerTestInitHelper#closeWorkDatabase()wurde hinzugefügt, um die Closeguard-Warnung zu Leaks von Ressourcen zu vermeiden. (Ia8d49)
Fehlerkorrekturen
- Es wurde die Möglichkeit hinzugefügt, overrideNextScheduleTimemitTestDriverzu umgehen, und es wurden Probleme mit der Testbarkeit behoben. (Ic2905)
Version 2.9.0-alpha01
7. Juni 2023
androidx.work:work-*:2.9.0-alpha01 ist veröffentlicht. Version 2.9.0-alpha01 enthält diese Commits.
Neue Funktionen
- Beobachtbarkeit über Flow. Anstelle vonLiveDatakann der Fortschritt des Workers jetzt über den Flow mitWorkManager.getWorkInfosFlowund ähnlichen Methoden beobachtet werden.
- Genaue Planung von periodischen Workern über setNextScheduleTimeOverride. So kann der nächste periodische Arbeitsplan dynamisch berechnet werden. Das kann verwendet werden, um erweiterte Funktionen wie adaptive Aktualisierungszeiten, benutzerdefiniertes Wiederholungsverhalten oder das Ausführen eines Newsfeed-Workers jeden Morgen vor dem Aufwachen des Nutzers ohne Drift zu implementieren.ExistingPeriodicWorkPolicy.UPDATEsollte in Kombination mit diesen Techniken verwendet werden, um zu vermeiden, dass ein aktuell ausgeführter Worker abgebrochen wird, während der nächste geplant wird.
- Die Tests von WorkManagerentsprechen der Produktion. MitExecutorsMode.PRESERVE_EXECUTORSkönnen inConfigurationfestgelegte Executors beibehalten und der tatsächliche Hauptthread verwendet werden.
- Coroutinen-APIs wie CoroutineWorkerwurden vom zusätzlichen Artefaktwork-runtime-ktxin das Hauptartefaktwork-runtimeverschoben.work-runtime-ktxist jetzt leer.
API-Änderungen
- Der Konstruktor von WorkInfoist jetzt öffentlich. Das kann beim Testen nützlich sein. (Ia00b6, b/209145335)
- work-runtime-ktxist jetzt leer.- CoroutineWorkerund andere Kotlin-spezifische Dienstprogramme sind jetzt im Hauptartefakt- work-runtimeverfügbar. (I71a9a)
- Die Methode setNextScheduleTimeOverridewurde hinzugefügt, mit der sich periodische Arbeitspläne genau festlegen lassen (I3b4da).
- getEarliestRunTimeMilliswurde in- getNextScheduleTimeMillisumbenannt. (I2bd7a)
- Informationen zur nächsten geplanten Ausführungszeit werden WorkInfohinzugefügt. (I797e4)
- WorkInfowerden Informationen zur anfänglichen Verzögerung und zur Periodizität hinzugefügt. (I52f2f)
- Methoden zum Beobachten von Workern über Flows über die Methoden getWorkInfosByTagFlow,getWorkInfoByIdFlow,getWorkInfosForUniqueWorkFlow,getWorkInfosFlowhinzugefügt (If122a)
- Fehlende @RequiresApi(...)-Anmerkungen zu Konstruktoren und Properties von Constraints hinzugefügt. Sie sind jetzt an entsprechende Anmerkungen zu Settern inConstraints.Builderangeglichen, die seit frühen Versionen vonWorkManagervorhanden sind. (I6d7d2)
- WorkManagerhat jetzt ein separates Limit für Content-URI-Worker, um ihnen garantierte Slots in- JobSchedulerzu geben und fehlende Inhaltsaktualisierungen bei hoher Last zu verhindern. Das Limit kann über- Configuration.Builder.setContentUriTriggerWorkersLimitkonfiguriert werden. (Ic128f)
- WorkInfowerden Einschränkungen hinzugefügt. (I162c0)
Version 2.8
Version 2.8.1
22. März 2023
androidx.work:work-*:2.8.1 ist veröffentlicht. Version 2.8.1 enthält diese Commits.
Fehlerkorrekturen
- Ein ANR-Fehler in RescheduleReceiverwurde behoben. Zuvor wurden zwei gleichzeitige Broadcasts nicht richtig verarbeitet. (b/236906724)
Version 2.8.0
8. Februar 2023
androidx.work:work-*:2.8.0 ist veröffentlicht. Version 2.8.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.7.0
Neue Funktionen
- Es wurde die Möglichkeit hinzugefügt, WorkRequestsauf nicht aufdringliche Weise zu aktualisieren, wobei die ursprüngliche Enqueue-Zeit, Verkettung usw. beibehalten werden. Weitere Informationen finden Sie im ausführlichen Blogpost zu dieser Funktion sowie in der Javadoc-Dokumentation fürWorkManager.updateWorkundExistingPeriodicWorkPolicy.UPDATE.
API-Änderungen
- WorkManager.updateWorkwurde hinzugefügt, um die Arbeit zu aktualisieren und dabei die ursprüngliche Enqueue-Zeit und Verkettung beizubehalten.(I9a248, b/219446409)
- ExistingPeriodicWorkPolicy.UPDATEwurde hinzugefügt. Mit dieser Richtlinie kann ein periodisches Werk anhand des Namens aktualisiert werden. Sie ähnelt der vorhandenen- REPLACE, ist aber weniger aufdringlich: Ein Worker wird nicht abgebrochen, wenn er gerade ausgeführt wird, und die Enqueue-Zeit bleibt erhalten. Die anfängliche Verzögerung und der Zeitraum werden anhand der ursprünglichen Enqueue-Zeit und nicht anhand der Aktualisierungszeit berechnet.- REPLACEwurde eingestellt, um Verwechslungen mit- REPLACEund- UPDATEzu vermeiden, die sehr ähnliche Namen haben. Wenn Sie die bisherige Semantik von- REPLACEbeibehalten möchten, können Sie die neu hinzugefügte Funktion- CANCEL_AND_REENQUEUEverwenden, die mit- REPLACEidentisch ist. (I985ed, b/219446409)
- Es wurde die Möglichkeit hinzugefügt, Planungsfehler abzufangen, indem Consumer<Throwable>über setSchedulingExceptionHandler bereitgestellt wird.
- Es wurde die Möglichkeit hinzugefügt, Consumer<Throwable>über setInitializationExceptionHandler bereitzustellen, um festzustellen, ob beim Initialisieren von WorkManager Probleme aufgetreten sind.
- Inline-Hilfen für OneTimeWorkRequestundPeriodicWorkRequestwurden vonandroidx.work:work-runtime-ktxnachandroidx.work:work-runtimeverschoben (I0010f, b/209145335)
- Die Hilfsmethoden WorkQuery.fromIds,WorkQuery.fromStates,WorkQuery.fromUniqueWorkNamesundWorkQuery.fromTagswurden hinzugefügt, umWorkQuerydirekt zu erstellen. (b/199919736) (If48f2, b/199919736)
- getForegroundInfowurde zu- Workerhinzugefügt. (Ic1ead)
- RxWorkersowohl für RxJava 2 als auch für RxJava 3 gibt jetzt- setForegroundzurück, das- Completablezurückgibt und anstelle von- setForegroundInfoAsyncverwendet werden kann, das- ListenableFuturezurückgibt.
- RxWorkersowohl für RxJava 2 als auch für RxJava 3 gibt- getForegroundInfozurück, das anstelle von- getForegroundInfoAsyncverwendet werden kann, das- ListenableFuturezurückgibt.- Single(b/203851459)
- Einschränkungen können jetzt direkt erstellt werden, anstatt Constraints.Builderzu verwenden. Das ist für Kotlin-Nutzer praktisch. (Idc390, b/137568653)
- Es wurde die Möglichkeit hinzugefügt, zu prüfen, ob WorkManagerinitialisiert wurde. Außerdem wurde eine neuegetConfiguration()API für Bibliotheksentwickler hinzugefügt, mit der die Konfiguration abgerufen werden kann, mit derWorkManagerinitialisiert wurde. (I6eff3, b/212300336)
Fehlerkorrekturen
- Ein Problem mit dem Greedy-Scheduler wurde behoben, das verhinderte, dass Worker unter Last sofort ausgeführt wurden. (I9686b, b/248111307)
- @RequiresPermissionwurde APIs hinzugefügt, für die die Berechtigung- POST_NOTIFICATIONSfür SDK 33 und höher erteilt werden muss. (Ie542e, b/238790278)
- Kündigungen in CoroutineScopeanListenableFutureweitergeben, wennsuspendCancellableCoroutineverwendet wird.
Version 2.8.0-rc01
7. Dezember 2022
androidx.work:work-*:2.8.0-rc01 ist veröffentlicht. Version 2.8.0-rc01 enthält diese Commits.
Neue Funktionen
- In diesem Release gibt es keine neuen Funktionen. Dies ist hauptsächlich eine Versionsaktualisierung.
Version 2.8.0-beta02
9. November 2022
androidx.work:work-*:2.8.0-beta02 ist veröffentlicht. Version 2.8.0-beta02 enthält diese Commits.
Fehlerkorrekturen
- Die Methode equalsinWorkInfowurde korrigiert. Bisher wurden Informationen zur neuen Generation nicht berücksichtigt. (4977cc)
Version 2.8.0-beta01
5. Oktober 2022
androidx.work:work-*:2.8.0-beta01 ist veröffentlicht. Version 2.8.0-beta01 enthält diese Commits.
Fehlerkorrekturen
- Ein Problem mit dem Greedy-Scheduler wurde behoben, das verhinderte, dass Worker unter Last sofort ausgeführt wurden. (I9686b, b/248111307)
Version 2.8.0-alpha04
7. September 2022
androidx.work:work-*:2.8.0-alpha04 ist veröffentlicht. Version 2.8.0-alpha04 enthält diese Commits.
API-Änderungen
- WorkerInfo.getGeneration()und- WorkerParameters.getGeneration()wurden hinzugefügt, um die Generation eines Workers zurückzugeben. Ein Worker hat mehrere Generationen, wenn er über- WorkManager.updateWorkoder- WorkManager.enqueueUniquePeriodicWorkmit- ExistingPeriodicWorkPolicy.UPDATEaktualisiert wurde. Hinweis: Wenn der Worker gerade ausgeführt wird, kann diese Methode eine neuere Generation als die des aktuell ausgeführten Workers zurückgeben, wenn während der Ausführung des Workers ein Update erfolgt ist. (I665c5, b/219446409) (I128a9, b/219446409)
- InitializationExceptionHandlerwurde hinzugefügt, ein Exception-Handler, mit dem sich feststellen lässt, ob beim Initialisieren von- WorkManagerProbleme aufgetreten sind. (I061de)
Version 2.8.0-alpha03
10. August 2022
androidx.work:work-*:2.8.0-alpha03 ist veröffentlicht. Version 2.8.0-alpha03 enthält diese Commits.
Neue Funktionen
- Es wurde die Möglichkeit hinzugefügt, WorkRequestsauf nicht aufdringliche Weise zu aktualisieren, wobei die ursprüngliche Enqueue-Zeit, Verkettung usw. beibehalten werden. Weitere Informationen finden Sie unterWorkManager.updateWorkundExistingPeriodicWorkPolicy.UPDATE.
API-Änderungen
- WorkManager.updateWorkwurde hinzugefügt, um die Arbeit zu aktualisieren und dabei die ursprüngliche Enqueue-Zeit und Verkettung beizubehalten.(I9a248, b/219446409)
- ExistingPeriodicWorkPolicy.UPDATEwurde hinzugefügt. Mit dieser Richtlinie kann ein periodisches Werk anhand des Namens aktualisiert werden. Sie ähnelt der vorhandenen- REPLACE, ist aber weniger aufdringlich: Ein Worker wird nicht abgebrochen, wenn er gerade ausgeführt wird, und die Enqueue-Zeit bleibt erhalten. Die anfängliche Verzögerung und der Zeitraum werden anhand der ursprünglichen Enqueue-Zeit und nicht anhand der Aktualisierungszeit berechnet.- REPLACEwurde eingestellt, um Verwechslungen mit dem sehr ähnlich benannten- REPLACEund- UPDATEzu vermeiden. Wenn Sie die bisherige Semantik von- REPLACEbeibehalten möchten, können Sie die neu hinzugefügte Funktion- CANCEL_AND_REENQUEUEverwenden, die mit- REPLACEidentisch ist. (I985ed, b/219446409)
- Es wurde die Möglichkeit hinzugefügt, Terminplanungs-Ausnahmen abzufangen, indem ein SchedulingExceptionHandlerdefiniert wird. (I033eb)
- Inline-Hilfen für OneTimeWorkRequestundPeriodicWorkRequestwurden vonandroidx.work:work-runtime-ktxnachandroidx.work:work-runtimeverschoben (I0010f, b/209145335)
Fehlerkorrekturen
- @RequiresPermissionwurde APIs hinzugefügt, für die die Berechtigung POST_NOTIFICATIONS für SDK 33 und höher erteilt werden muss. (Ie542e, b/238790278)
Version 2.8.0-alpha02
6. April 2022
androidx.work:work-*:2.8.0-alpha02 ist veröffentlicht. Version 2.8.0-alpha02 enthält diese Commits.
API-Änderungen
- Einschränkungen können jetzt direkt erstellt werden, anstatt den Builder zu verwenden. Das ist für Kotlin-Nutzer praktisch. (Idc390, b/137568653)
- Es wurde die Möglichkeit hinzugefügt, zu prüfen, ob WorkManagerinitialisiert wurde. Außerdem wurde eine neuegetConfiguration()API für Bibliotheksentwickler hinzugefügt, mit der die Konfiguration abgerufen werden kann, mit derWorkManagerinitialisiert wurde. (I6eff3, b/212300336)
Version 2.8.0-alpha01
12. Januar 2022
androidx.work:work-*:2.8.0-alpha01 ist veröffentlicht. Version 2.8.0-alpha01 enthält diese Commits.
API-Änderungen
- Es wurden Hilfsmethoden WorkQuery.fromStates,WorkQuery.fromUniqueWorkNamesundWorkQuery.fromTagshinzugefügt, um WorkQuery direkt zu erstellen. (If48f2, b/199919736)
- Es wurden experimentelle BuildCompat-Methoden für zukünftige SDKs hinzugefügt (Iafd82, b/207528937).
- Fügen Sie getForegroundInfozuWorkerhinzu. (Ic1ead)
- Es wurden Hilfsmethoden WorkQuery.fromIdszum direkten Erstellen von WorkQuery aus IDs hinzugefügt. (Ie5bdf, b/199919736)
- RxWorker hat jetzt setForeground, dasCompletablezurückgibt und anstelle vonsetForegroundInfoAsyncverwendet werden kann, dasListenableFuturezurückgibt. (I85156)
- RxWorker für RxJava 2 gibt jetzt Singlezurück, wenngetForegroundInfoaufgerufen wird.Singlekann anstelle vongetForegroundInfoAsyncverwendet werden, dasListenableFuturezurückgibt. (I21c91, b/203851459)
- RxWorker für RxJava 3 hat jetzt getForegroundInfo, dasSinglezurückgibt und anstelle vongetForegroundInfoAsyncverwendet werden kann, dasListenableFuturezurückgibt. (I1ca8a)
- RxWorker hat jetzt setForeground, dasCompletablezurückgibt und anstelle vonsetForegroundInfoAsyncverwendet werden kann, dasListenableFuturezurückgibt. (I992a3, b/203851459)
Fehlerkorrekturen
- Kündigungen in CoroutineScopeanListenableFutureweitergeben, wennsuspendCancellableCoroutineverwendet wird. (I77e63)
Version 2.7
Version 2.7.1
17. November 2021
androidx.work:work-*:2.7.1 ist veröffentlicht. Version 2.7.1 enthält diese Commits.
Fehlerkorrekturen
- Kündigungen im CoroutineScopewerden bei Verwendung vonsuspendCancellableCoroutinean dasListenableFutureweitergegeben. (I77e63)
- Eine Ausnahme wird sofort ausgelöst, wenn verzögerte Arbeitsanfragen als beschleunigt markiert werden. bef1762
Version 2.7.0
13. Oktober 2021
androidx.work:work-*:2.7.0 ist veröffentlicht. Version 2.7.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.6.0
- WorkManager führt eine neue - WorkRequest.Builder.setExpedited(...)API ein, um die Einschränkungen für Dienste im Vordergrund in Android 12 zu berücksichtigen.
- Wenn Sie - setExpedited(...)verwenden, delegiert WorkManager ab Android 12 an beschleunigte Jobs in JobScheduler. Für frühere Android-Versionen wird durch die Delegation an einen Dienst im Vordergrund Abwärtskompatibilität geboten.
Version 2.7.0-rc01
29. September 2021
androidx.work:work-*:2.7.0-rc01 ist veröffentlicht. Version 2.7.0-rc01 enthält diese Commits.
Diese Version ist identisch mit androidx.work:work-*:2.7.0-beta01.
Version 2.7.0-beta01
1. September 2021
androidx.work:work-*:2.7.0-beta01 ist veröffentlicht. Version 2.7.0-beta01 enthält diese Commits.
Neue Funktionen
- Reduzierung von SQLite-Konflikten in mehreren Prozessen bei der Initialisierung von WorkManager.
API-Änderungen
- Entfernen Sie @ExperimentalExpeditedWorkAPIs, da die zugrunde liegenden Plattform-APIs für Android 12 (S) stabil sind. (aosp/1792806)
Fehlerkorrekturen
- Eine bessere Fehlermeldung für Mitarbeiter, die getForegroundInfoAsync()nicht implementieren. (aosp/1809376)
Version 2.7.0-alpha05
21. Juli 2021
androidx.work:work-*:2.7.0-alpha05 ist veröffentlicht. Version 2.7.0-alpha05 enthält diese Commits.
Diese Version enthält auch Fehlerkorrekturen aus der WorkManager-Version 2.6.0-beta02.
Version 2.7.0-alpha04
2. Juni 2021
androidx.work:work-*:2.7.0-alpha04 ist veröffentlicht.
Diese Version enthält auch die Änderungen aus der Version 2.6.0-beta01.
API-Änderungen
- ListenableWorker.setForegroundAsync()ist nicht mehr eingestellt.
- Wir empfehlen, nach Möglichkeit die WorkRequest.Builder.setExpedited(...)API zu verwenden. Um Situationen besser zu unterstützen, in denen die App keinen Einschränkungen für Dienste im Vordergrund unterliegt, können Entwickler dieListenableWorker.setForegroundAsync()API verwenden.
- Wenn ListenableWorker.setForegroundAsync()aufgerufen wird, während für die App Einschränkungen für Dienste im Vordergrund gelten, wird die ForegroundServiceStartNotAllowedException ausgelöst.
Fehlerkorrekturen
- Wenn beschleunigte Jobs neu geplant werden, sind sie nicht mehr beschleunigt. Sie werden zu regulären Jobs.
Version 2.7.0-alpha03
21. April 2021
androidx.work:work-*:2.7.0-alpha03 ist veröffentlicht. Version 2.7.0-alpha03 enthält diese Commits.
Neue Funktionen
- Ab WorkManager - 2.6.0-alpha02: Unterstützung für Workers, die in jedem Prozess ausgeführt werden können. (Iaf200)
- Aus WorkManager - 2.6.0-alpha02: Es wurde- RemoteCoroutineWorkerhinzugefügt, eine Implementierung von- RemoteListenableWorker, die an einen Remote-Prozess gebunden werden kann. (I30578)
API-Änderungen
- WorkManager 2.6.0-alpha02:TEMPORARILY_UNMETERED-Netzwerkbeschränkung wird jetzt unterstützt. (I08d5e)
- Aus WorkManager 2.6.0-alpha02:Unterstützung von Worker-Prozessen fürsetProgressAsync(). (Ib6d08)
- Über WorkManager 2.6.0-alpha02:Machen SieWorkManagerInitializeröffentlich, damit andereandroidx.startup.Initializers sie als Abhängigkeiten verwenden können. (I5ab11)
Version 2.7.0-alpha02
10. März 2021
androidx.work:work-*:2.7.0-alpha02 ist veröffentlicht. Version 2.7.0-alpha02 enthält diese Commits.
Fehlerkorrekturen
- Die Veränderlichkeit von PendingIntentwird explizit angegeben, um einen Absturz bei der Ausrichtung auf Android 12 zu beheben. (b/180884673)
Version 2.7.0-alpha01
18. Februar 2021
androidx.work:work-*:2.7.0-alpha01 ist veröffentlicht. Version 2.7.0-alpha01 enthält diese Commits.
Neue Funktionen
- WorkManager führt eine neue - WorkRequest.Builder.setExpedited(...)API ein, um die Einschränkungen für Dienste im Vordergrund in Android 12 zu berücksichtigen.- Apps können keinen Dienst im Vordergrund mehr starten, wenn sie im Hintergrund ausgeführt werden. Um lang andauernde Aufgaben, die zuvor an den Lebenszyklus eines Dienstes im Vordergrund gebunden waren, besser zu unterstützen, können Anwendungen - WorkRequestals beschleunigt markieren.- Diese API ersetzt die APIs - setForegroundAsync(...)/- setForeground(...), die jetzt eingestellt wurden.- Bei Verwendung von - setExpedited(...)delegiert WorkManager ab Android 12 an beschleunigte Jobs in- JobScheduler. Für frühere Android-Versionen wird durch die Delegierung an Dienste im Vordergrund Abwärtskompatibilität bereitgestellt.
API-Änderungen
- Unterstützung für beschleunigte WorkRequests hinzugefügt.
Version 2.6.0
Version 2.6.0
1. September 2021
androidx.work:work-*:2.6.0 ist veröffentlicht. Version 2.6.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.5.0
- WorkManager verwendet jetzt - androidx.startup, um WorkManager zu initialisieren. Wenn Sie- tools:node="remove"verwendet haben, um- ContentProviderin der Vergangenheit zu initialisieren, müssen Sie stattdessen Folgendes tun.- <provider android:name="androidx.startup.InitializationProvider" android:authorities=\"${applicationId}.androidx-startup" android:exported="false" tools:node=\"merge"> <!-- If you are using androidx.startup to initialize other components --> <meta-data android:name="androidx.work.WorkManagerInitializer" android:value="androidx.startup" tools:node="remove" /> </provider>- <!-- If you want to disable android.startup completely. --> <provider android:name="androidx.startup.InitializationProvider" android:authorities="${applicationId}.androidx-startup" tools:node="remove" />
- Unterstützung für Worker, die in einem beliebigen Prozess ausgeführt werden können, wurde hinzugefügt. (Iaf200) 
- Es wurde ein - RemoteCoroutineWorkerhinzugefügt, eine Implementierung von RemoteListenableWorker, die an einen Remote-Prozess gebunden werden kann. (I30578)
Version 2.6.0-rc01
4. August 2021
androidx.work:work-*:2.6.0-rc01 ist veröffentlicht. Version 2.6.0-rc01 enthält diese Commits.
Diese Version ist identisch mit androidx.work:work-*:2.6.0-beta02.
Version 2.6.0-beta02
21. Juli 2021
androidx.work:work-*:2.6.0-beta02 ist veröffentlicht. Version 2.6.0-beta02 enthält diese Commits.
Fehlerkorrekturen
- RemoteWorkManagerwird jetzt korrekt von- RemoteWorkManagerServiceentbunden, sodass- RemoteWorkManagerServicekorrekt bereinigt werden kann. aosp/1730694
- RemoteListenableWorkerwird jetzt korrekt von- RemoteWorkerServicegetrennt, sodass- RemoteWorkerServicekorrekt bereinigt werden kann. aosp/1743817
- ForceStopRunnablewird jetzt nur noch im primären App-Prozess ausgeführt. Dies ist eine Optimierung, die Ressourcenkonflikte für Apps mit mehreren Prozessen vermeidet. aosp/1749180, aosp/1761729
Version 2.6.0-beta01
2. Juni 2021
androidx.work:work-*:2.6.0-beta01 ist veröffentlicht. Version 2.6.0-beta01 enthält diese Commits.
Diese Version enthält einige kleinere Verbesserungen an der Dokumentation. Die Version ist weitgehend identisch mit 2.6.0-alpha02.
Version 2.6.0-alpha02
21. April 2021
androidx.work:work-*:2.6.0-alpha02 ist veröffentlicht. Version 2.6.0-alpha02 enthält diese Commits.
Neue Funktionen
- Unterstützung für Worker, die in jedem Prozess ausgeführt werden können, wurde hinzugefügt. (Iaf200) 
- Es wurde ein - RemoteCoroutineWorkerhinzugefügt, das eine Implementierung von- RemoteListenableWorkerist, die an einen Remote-Prozess gebunden werden kann. (I30578)
API-Änderungen
- Unterstützung für die Netzwerkbeschränkung TEMPORARILY_UNMETEREDhinzugefügt. (I08d5e)
- Unterstützung von Worker-Prozessen für setProgressAsync(). (Ib6d08)
- Machen Sie WorkManagerInitializeröffentlich, damit andereandroidx.startup.Initializers sie als Abhängigkeiten verwenden können. (I5ab11)
Version 2.6.0-alpha01
24. März 2021
androidx.work:work-*:2.6.0-alpha01 ist veröffentlicht. Version 2.6.0-alpha01 enthält diese Commits.
Neue Funktionen
- WorkManagerverwendet jetzt- androidx.startup, um WorkManager zu initialisieren. Bisher wurde dies von- androidx.work.impl.WorkManagerInitializererledigt. (aosp/1608813)- Wenn Sie - tools:node="remove"in der Vergangenheit zum Initialisieren des Prozesslebenszyklus verwendet haben, müssen Sie stattdessen Folgendes tun.- ContentProvider- <provider android:name="androidx.startup.InitializationProvider" android:authorities=\"${applicationId}.androidx-startup" android:exported="false" tools:node=\"merge"> <!-- If you are using androidx.startup to initialize other components --> <meta-data android:name="androidx.work.impl.WorkManagerInitializer" android:value="androidx.startup" tools:node="remove" /> </provider>- (oder) - <!-- If you want to disable android.startup completely. --> <provider android:name="androidx.startup.InitializationProvider" android:authorities="${applicationId}.androidx-startup" tools:node="remove"> </provider>
API-Änderungen
- Fügen Sie eine Result.getOutputData()-API hinzu, die dieoutputDatavon ListenableWorker zurückgibt. (Ie51e3)
Fehlerkorrekturen
- Es wurde eine Problemumgehung für einen OEM-Fehler hinzugefügt, der dazu führt, dass bei Verwendung der AlarmManager-APIs einSecurityExceptionausgelöst wird. (aosp/1587518)
Version 2.5.0
Version 2.5.0
27. Januar 2021
androidx.work:work-*:2.5.0 ist veröffentlicht. Version 2.5.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.4.0
- Ein neues :work:work-multiprocess-Artefakt für Apps, die mehrere Prozesse verwenden. Dadurch wird die Leistung verbessert, da die Planung von Arbeitsanfragen in einem einzigen Prozess zusammengefasst wird.- Wenn Sie work-multiprocessverwenden möchten, definieren Sie eine Abhängigkeit von:implementation "androidx.work:work-multiprocess:2.5.0"
- Legen Sie mit Configuration.Builder.setDefaultProcessName(String) einen primären Prozess fest.
- Wenn Sie work-multiprocessverwenden, sollten Sie auch RemoteWorkManager verwenden, um IhreWorkRequests zu verwalten. RemoteWorkManager kontaktiert immer den zugewiesenen Prozess. Der In-Process-Scheduler wird ebenfalls im dafür vorgesehenen Prozess ausgeführt.
 
- Wenn Sie 
- Manchmal kann ActivityManagerdieJobService-Instanz nicht instanziieren, um einen Job zu starten. Dies führt dazu, dass der zugrunde liegende Job aufgrund eines Plattformfehlers ohne Benachrichtigung gelöscht wird.WorkManagersorgt jetzt dafür, dass es Sicherungsjobs für jede einzelneWorkRequestgibt, wenn eineApplicationdurch Abgleichsjobs initialisiert wird. Dies verbessert die Zuverlässigkeit der Jobausführung erheblich. (b/172475041, aosp/1489577)
- WorkManagerbegrenzt das Datenbankwachstum, indem die Pufferdauer reduziert wird, in der- WorkRequestnach Abschluss eines- WorkRequesterfasst werden. Die Dauer betrug zuvor- 7Tage. Sie wurde auf- 1Tag + die Dauer von keepResultsForAtLeast reduziert. (aosp/1419708)
- Die TestListenableWorkerBuilderunterstützt jetzt die reifizierte Klasse, dieListenableWorkererweitert, um das Testen zu vereinfachen. (aosp/1443299, b/169787349)
- Der WorkManager-Inspector ist jetzt verfügbar, wenn Sie Android Studio Arctic Fox verwenden.
Version 2.5.0-rc01
13. Januar 2021
androidx.work:work-*:2.5.0-rc01 ist veröffentlicht. Version 2.5.0-rc01 enthält diese Commits.
Fehlerkorrekturen
- Ein Fehler wurde behoben, bei dem getWorkInfosLiveDatanach der Aktualisierung von Einheiten bei Verwendung derWorkQuery-basierten API nicht richtig ungültig gemacht wurde. (aosp/1540566, b/173769028)
- Es wurde ein Fehler behoben, durch den Datenbanktransaktionen in seltenen Fällen nicht als erfolgreich markiert wurden. Dies führt auf einigen Motorola-Geräten zu Problemen. (aosp/1535368, b/175944460)
- Ein Fehler wurde behoben, durch den NoSuchElementExceptions ignoriert wurden, wenn versucht wurde, die Bindung an einen beendeten Prozess aufzuheben. (aosp/1530589)
- Verbessere ConstraintTrackingWorkerso, dass nur einListenableWorkerbeendet wird, wenn es noch nicht beendet wurde. (aosp/1496844, b/172946965)
- androidx.work-Bibliotheken für Java 8 aktualisieren (Ibd2f2)
Version 2.5.0-beta02
2. Dezember 2020
androidx.work:work-*:2.5.0-beta02 ist veröffentlicht. Version 2.5.0-beta02 enthält diese Commits.
Fehlerkorrekturen
- Ein Fehler in androidx.work:work-multiprocesswurde behoben, bei dem WorkManager den aufrufenden Thread versehentlich blockierte, als versucht wurde, eine Verbindung zum angegebenen Prozess herzustellen. (aosp/1475538)
- Ein Fehler wurde behoben, bei dem PeriodicWorkRequestnicht richtig abgeglichen wurden. (b/172475041, aosp/1489577)
- Es wurde eine Problemumgehung für einen Plattformfehler beim Beenden des Vordergrunddienstes bei Verwendung der setForeground*APIs hinzugefügt. (b/170924044, aosp/1489901)
Version 2.5.0-beta01
28. Oktober 2020
androidx.work:work-*:2.5.0-beta01 ist veröffentlicht. Version 2.5.0-beta01 enthält diese Commits.
Neue Funktionen
- WorkManagerdrosselt automatisch die Anzahl der- WorkRequests, die vom In-Process-Scheduler aufgenommen werden können. Die Anfragen werden weiterhin in der Reihenfolge ihres Eingangs ausgeführt. (aosp/1455228)
- WorkManagerversucht, den Zustand wiederherzustellen, wenn sich der Datenspeicher der Anwendung in einem fehlerhaften Zustand befindet. (aosp/1463103)
Fehlerkorrekturen
- Wenn ListenableWorkerunterbrochen werden, markieren Sie sie sofort alsENQUEUED, damit sie später neu geplant werden können. (aosp/1455618, b/170273988)
Version 2.5.0-alpha03
14. Oktober 2020
androidx.work:work-*:2.5.0-alpha03 ist veröffentlicht. Version 2.5.0-alpha03 enthält diese Commits.
API-Änderungen
- TestListenableWorkerBuilderund- TestWorkerBuilderverwenden keine Raw-Typen. (I883ad, b/169787349)
Fehlerkorrekturen
- Verwenden Sie ApplicationInfo, um den Namen des Standard-App-Prozesses zu ermitteln. (b/168716641, aosp/1429950)
- Korrigieren Sie die Sichtbarkeitsregeln für RemoteWorkManagerundRemoteWorkContinuation. Diese APIs sind nicht mehr als@Restrictedgekennzeichnet. (aosp/1432091)
- Korrigieren Sie die ProGuard-Regeln für :work:work-multiprocess. (aosp/1432091)
- Der Benachrichtigungslebenszyklus für lang andauernde Aufgaben, die an einen Vordergrunddienst gebunden sind, wurde verbessert. (b/168502234, aosp/1431331)
Version 2.5.0-alpha02
16. September 2020
androidx.work:work-*:2.5.0-alpha02 ist veröffentlicht. Version 2.5.0-alpha02 enthält diese Commits.
Neue Funktionen
- Fügen Sie WorkQuery eine API hinzu, damit Sie ids verwenden können, umWorkInfos abzufragen. (aosp/1412372, b/157335295)
- WorkManager unterstützt Apps, die mehrere Prozesse verwenden, jetzt besser mit einem neuen Artefakt (androidx.work:work-multiprocess:*). Dieses neue Artefakt hilft, einige Probleme zu beheben, die bei großen Apps auftreten, darunter:- WorkManager muss in der Regel in jedem App-Prozess initialisiert werden. Das ist nicht optimal, da es zu mehr SQLite-Konflikten kommt, was wiederum andere Probleme verursacht. WorkManager bietet jetzt neue APIs, mit denen Sie mit Configuration#setDefaultProcessName(processName)einen primären App-Prozess festlegen können.processNameist ein vollständig qualifizierter Prozessname, der wiepackageName:processNameaussieht (z.B.com.example:remote).
- Eine Reihe neuer APIs: RemoteWorkManagerundRemoteWorkContinuationbisenqueue,cancelundquery-Arbeitsanfragen. Diese APIs enthalten keineLiveData-Varianten, um SQLite-Konflikte zwischen mehreren Prozessen zu vermeiden. Alle Aufrufe vonenqueue,cancelundquerywerden mithilfe von AIDL an einenprimary-App-Prozess weitergeleitet und geben einen flüssigenListenableFuturezurück. (aosp/1392657, aosp/1411210, aosp/1412215, aosp/1417713)
 
- WorkManager muss in der Regel in jedem App-Prozess initialisiert werden. Das ist nicht optimal, da es zu mehr SQLite-Konflikten kommt, was wiederum andere Probleme verursacht. WorkManager bietet jetzt neue APIs, mit denen Sie mit 
API-Änderungen
- WorkManager löscht jetzt abgeschlossene WorkRequests ohne unvollständige Abhängigkeiten aggressiver. Die Pufferdauer wurde von7Tagen auf1Tag geändert. (aosp/1419708)
Fehlerkorrekturen
- WorkManager gleicht Jobs jetzt proaktiv ab, sodass WorkRequest- undJobScheduler-Jobs synchronisiert werden, wennWorkManagerinitialisiert wird. (aosp/1412794, b/166292069)
Version 2.5.0-alpha01
19. August 2020
androidx.work:work-*:2.5.0-alpha01 ist veröffentlicht. Version 2.5.0-alpha01 enthält diese Commits.
Neue Funktionen
- Änderungen an internen APIs, die es uns ermöglichen, in Zukunft bessere Tools mit WorkManagerbereitzustellen. Wir halten Sie auf dem Laufenden.
Fehlerkorrekturen
- Behandlung von SecurityExceptionbeim Erfassen des Netzwerkstatus auf einigen Geräten. (aosp/1396969)
Externe Beiträge
- Dokumentation für ArrayCreatingInputMergervon Zac Sweers (github/43) korrigiert.
Version 2.4.0
Version 2.4.0
22. Juli 2020
androidx.work:work-*:2.4.0 ist veröffentlicht. Version 2.4.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.3.0
- Der In-Process-Scheduler von WorkManagerist jetzt leistungsfähiger. Bisher wurden bei der In-Process-Schedulernur Arbeiten ausgeführt, die nicht verzögert wurden und deren Einschränkungen erfüllt waren. Der In-Process-Scheduler verfolgt jetztWorkRequests, die in Zukunft ausgeführt werden könnten, einschließlich PeriodicWorkRequests. Das In-Process-Schedulerunterliegt auch keinen Planungsbeschränkungen, ist aber weiterhin auf die Größe des von WorkManager verwendetenExecutorbeschränkt. Das bedeutet, dass die App jetzt viel mehr WorkRequests ausführen kann, wenn sie im Vordergrund ist. Zur Verwaltung der Ausführung verzögerter Aufgaben im Vordergrund wird inWorkManagerauch ein neues konfigurierbaresRunnableSchedulereingeführt. (aosp/1185778)
- WorkManager unterstützt jetzt RxJava 3. Wenn Sie RxJava 3 verwenden möchten, müssen Sie die folgende Abhängigkeit einfügen: implementation "androidx.work:work-rxjava3:2.4.0". (aosp/1277904)
- Es ist jetzt möglich, WorkInfos mit einemWorkQueryabzufragen. Das ist nützlich, wenn EntwicklerWorkInfos anhand einer Kombination aus mehreren Attributen abfragen möchten. Weitere Informationen finden Sie unterWorkQuery.Builder.fromStates(...),WorkQuery.Builder. fromTags(...)oderWorkQuery.Builder.fromUniqueWorkNames(...). (aosp/1253230, b/143847546)
- Fügen Sie die Möglichkeit hinzu, Diagnoseinformationen von - WorkManageranzufordern, indem Sie Folgendes verwenden:- adb shell am broadcast -a "androidx.work.diagnostics.REQUEST_DIAGNOSTICS" -p "<your_app_package_name>"- Sie enthält viele nützliche Informationen, darunter: - WorkRequests, die in den letzten 24 Stunden abgeschlossen wurden.
- WorkRequests, die derzeit ausgeführt werden.
- Geplante Arbeitsanfragen. (aosp/1235501)
 
- Fügen Sie - ExistingWorkPolicy.APPEND_OR_REPLACEhinzu. Das ist ähnlich wie- APPEND, ersetzt aber eine Kette mit abgebrochenen oder fehlgeschlagenen Voraussetzungen. (b/134613984, aosp/1199640)
- Es ist möglich, ein benutzerdefiniertes - RunnableSchedulerhinzuzufügen, um WorkRequests zu verfolgen, die in Zukunft ausgeführt werden müssen. Dies wird vom In-Process-Scheduler verwendet. (aosp/1203944)
- Unterstützung für das dynamische Hinzufügen von Factories zum Delegieren bei Verwendung von - DelegatingWorkerFactoryhinzugefügt. (b/156289105, aosp/1309745)
- Das Tracking für - BATTERY_NOT_LOW-Einschränkungen wird besser an die Plattform angepasst. (aosp/1312583)
- Der In-Process-Scheduler verwendet jetzt bessere APIs, um den Namen des Prozesses zu ermitteln. Dies ist nützlich, um Apps mit mehreren Prozessen besser zu unterstützen. (aosp/1324732) 
- Neue Lint-Regeln, die Folgendes erzwingen: - Verwendung der richtigen foregroundServiceTypebei Verwendung vonsetForegroundAsync()-APIs. (b/147873061, aosp/1215915)
- Geben Sie JobScheduler-IDs an, die WorkManager verwenden soll, wenn JobService-APIs direkt verwendet werden. aosp/1223567
- Es wurde eine neue Lint-Regel hinzugefügt, die dafür sorgt, dass ListenableWorker-Implementierungen jetztpublicsind, wenn die Standard-WorkerFactoryverwendet wird. (aosp/1291262)
 
- Verwendung der richtigen 
- Aufrufe von - setForegroundAsync(), die nicht vor Abschluss eines- ListenableWorkerabgeschlossen werden, werden jetzt über ein- IllegalStateExceptionim zurückgegebenen- ListenableFuturesignalisiert. (aosp/1262743)
- Ein Fehler wurde behoben, durch den die - ForegroundServicenicht beendet wurde, nachdem eine- Workerim Vordergrund unterbrochen wurde. (b/155579898, aosp/1302153)
- Ein Fehler wurde behoben, bei dem - WorkManagerversucht, mehrere Instanzen von- Workerauszuführen, die an einen Vordergrunddienst gebunden sind (b/156310133, aosp/1309853).
Version 2.4.0-rc01
24. Juni 2020
androidx.work:work-*:2.4.0-rc01 ist veröffentlicht. Version 2.4.0-rc01 enthält diese Commits.
Fehlerkorrekturen
- Der In-Process-Scheduler verwendet jetzt bessere APIs, um den Namen des Prozesses zu ermitteln. Dies ist nützlich, um Apps mit mehreren Prozessen besser zu unterstützen. (aosp/1324732)
Version 2.4.0-beta01
20. Mai 2020
androidx.work:work-gcm:2.4.0-beta01, androidx.work:work-runtime:2.4.0-beta01, androidx.work:work-runtime-ktx:2.4.0-beta01, androidx.work:work-rxjava2:2.4.0-beta01 und androidx.work:work-testing:2.4.0-beta01 sind veröffentlicht. Version 2.4.0-beta01 enthält diese Commits.
Fehlerkorrekturen
- Ein Fehler wurde behoben, durch den die ForegroundServicenicht beendet wurde, nachdem eineWorkerim Vordergrund unterbrochen wurde. (b/155579898, aosp/1302153)
- Ein Fehler wurde behoben, bei dem WorkManagerversucht, mehrere Instanzen vonWorkerauszuführen, die an einen Vordergrunddienst gebunden sind (b/156310133, aosp/1309853).
- Unterstützung für das dynamische Hinzufügen von Factories zum Delegieren bei Verwendung von DelegatingWorkerFactoryhinzugefügt. (b/156289105, aosp/1309745)
- Das Tracking für BATTERY_NOT_LOW-Einschränkungen wird besser an die Plattform angepasst. (aosp/1312583)
Version 2.4.0-alpha03
29. April 2020
androidx.work:work-*:2.4.0-alpha03 ist veröffentlicht. Version 2.4.0-alpha03 enthält diese Commits.
Neue Funktionen
- WorkManager unterstützt jetzt RxJava 3. Wenn Sie RxJava 3 verwenden möchten, müssen Sie die folgende Abhängigkeit einfügen: implementation "androidx.work:work-rxjava3:2.4.0-alpha03". (aosp/1277904)
- Es wurde eine neue Lint-Regel hinzugefügt, die dafür sorgt, dass ListenableWorker-Implementierungen jetztpublicsind, wenn die Standard-WorkerFactoryverwendet wird. (aosp/1291262)
API-Änderungen
- Wenn Sie setProgressAsync()aufrufen, nachdem die Ausführung einesListenableWorkerabgeschlossen ist, wird jetzt überListenableFutureeinExceptionsignalisiert. (aosp/1285494)
- WorkQuery.Builderist jetzt mit- finalgekennzeichnet. (aosp/1275037)
- Die WorkQuery.Builder-Factory-MethodenwithStates,withTagsundwithUniqueWorkNameswurden infromStates,fromTagsundfromUniqueWorkNamesumbenannt. (aosp/1280287)
Fehlerkorrekturen
- Ignoriere SecurityExceptions beim Erfassen des Netzwerkstatus eines Geräts. (b/153246136, aosp/1280813)
Version 2.4.0-alpha02
1. April 2020
androidx.work:work-*:2.4.0-alpha02 ist veröffentlicht. Version 2.4.0-alpha02 enthält diese Commits.
Neue Funktionen
- Es wurde eine neue Lint-Regel hinzugefügt, die warnt, wenn für WorkRequestsowohlConstraints.setRequiresCharging(...)als auchConstraints.setRequiresDeviceIdle(...)erforderlich sind. Einige Geräte werden nie gleichzeitig geladen und sind im Leerlauf. Solche Anfragen würden also seltener als erwartet ausgeführt. (aosp/1253840)
API-Änderungen
- Es ist jetzt möglich, - WorkInfos mit einem- WorkQueryabzufragen. Das ist nützlich, wenn Entwickler- WorkInfos anhand einer Kombination aus mehreren Attributen abfragen möchten. Weitere Informationen finden Sie unter- WorkQuery.Builder withStates(...),- WorkQuery.Builder withTags(...)oder- WorkQuery.Builder withUniqueWorkNames(...). (aosp/1253230, b/143847546)
- Aufrufe von - setForegroundAsync(), die nicht vor Abschluss eines- ListenableWorkerabgeschlossen werden, werden jetzt über ein- IllegalStateExceptionim zurückgegebenen- ListenableFuturesignalisiert. (aosp/1262743)
Fehlerkorrekturen
- Die Lint-Regel, mit der nach ungültigen Intervallzeiträumen für PeriodicWorkRequestgesucht wird, wurde korrigiert. (aosp/1254846, b/152606442)
Version 2.4.0-alpha01
4. März 2020
androidx.work:work-*:2.4.0-alpha01 ist veröffentlicht. Version 2.4.0-alpha01 enthält diese Commits.
Neue Funktionen
- Der In-Process-Scheduler von - WorkManagerist jetzt leistungsfähiger. Bisher hat der In-Process-Scheduler nur die Ausführung von Aufgaben in Betracht gezogen, die nicht verzögert wurden und deren Einschränkungen erfüllt waren. Der In-Process-Scheduler verfolgt jetzt- WorkRequest, die in Zukunft ausgeführt werden könnten, einschließlich- PeriodicWorkRequest. Der In-Process-Scheduler beachtet auch keine Planungsbeschränkungen (ist aber weiterhin auf die Größe des von WorkManager verwendeten- Executorbeschränkt). Das bedeutet, dass die Anwendung jetzt viel mehr- WorkRequests ausführen kann, wenn sie im Vordergrund ausgeführt wird. (aosp/1185778)
- Es wurde die Möglichkeit hinzugefügt, mit - adb shell am broadcast -a "androidx.work.diagnostics.REQUEST_DIAGNOSTICS" -p "<your_app_package_name>"Diagnoseinformationen von WorkManager anzufordern. Sie enthält viele nützliche Informationen, darunter:- WorkRequests, die in den letzten 24 Stunden abgeschlossen wurden.
- WorkRequests, die derzeit ausgeführt werden.
- Geplante Arbeitsanfragen. (aosp/1235501)
 
- Neue Lint-Regeln, die Folgendes erzwingen: - Verwendung der richtigen foregroundServiceTypebei Verwendung vonsetForegroundAsync()-APIs. (b/147873061, aosp/1215915)
- Gibt JobScheduler-IDs an, dieWorkManagerbei der direkten Verwendung vonJobService-APIs verwenden soll. (aosp/1223567)
 
- Verwendung der richtigen 
API-Änderungen
- Fügen Sie - ExistingWorkPolicy.APPEND_OR_REPLACEhinzu, das- APPENDähnelt, aber eine Kette ersetzt, bei der Voraussetzungen abgebrochen oder nicht erfüllt wurden. (b/134613984, aosp/1199640)
- Es soll möglich sein, ein benutzerdefiniertes - RunnableSchedulerhinzuzufügen, um- WorkRequestzu erfassen, die in Zukunft ausgeführt werden müssen. Dies wird vom In-Process-Scheduler verwendet. (aosp/1203944)
Fehlerkorrekturen
- setProgress()in- RxWorkerwurde eingestellt, da zuvor ein- Single<Void>zurückgegeben wurde, was ein unmöglicher Typ ist. Eine neue API- setCompletableProgress()wurde hinzugefügt, die stattdessen- Completablezurückgibt. Außerdem wurden neue Lint-Regeln hinzugefügt, die bei der Migration zu den neuen APIs helfen. (b/150080946, aosp/1242665)
Version 2.3.4
Version 2.3.4
18. März 2020
androidx.work:work-*:2.3.4 ist veröffentlicht. Version 2.3.4 enthält diese Commits.
Fehlerkorrekturen
- Ein Fehler wurde behoben, der dazu führte, dass mehrere Instanzen eines lang andauernden Workerausgeführt wurden, nachdem das 10-minütige Ausführungsfenster überschritten wurde. (aosp/1247484, b/150553353)
- Korrektur für den WorkManager-Lint IssueRegistry. Vielen Dank an @ZacSweers von Slack für den Beitrag. (aosp/1217923)
Version 2.3.3
Version 2.3.3
4. März 2020
androidx.work:work-*:2.3.3 ist veröffentlicht. Version 2.3.3 enthält diese Commits.
Fehlerkorrekturen
- Ein Fehler wurde behoben, bei dem eine unterbrochene Workernicht richtig neu geplant wurde. (b/150325687, aosp/1246571)
Version 2.3.2
Version 2.3.2
19. Februar 2020
androidx.work:work-*:2.3.2 werden veröffentlicht. Version 2.3.2 enthält diese Commits.
Fehlerkorrekturen
- Ein Problem wurde behoben, bei dem WorkManager in seltenen Fällen das Limit von 100 Jobs in JobScheduler überschritt. (aosp/1226859, b/149092520)
- Behebung einer Race-Bedingung in ConstraintControllers. (aosp/1220100)
- Der Lebenszyklus von Foreground-Diensten für lang andauernde Worker wurde verbessert. (aosp/1226295)
- Die Verwaltung der Stornierung von Benachrichtigungen für lang laufende Worker bei der Stornierung von Workern wurde verbessert. (aosp/1228346)
Version 2.3.1
Version 2.3.1
5. Februar 2020
androidx.work:work-*:2.3.1 ist veröffentlicht.  Version 2.3.1 enthält diese Commits.
Fehlerkorrekturen
- Den Lebenszyklus von Notifications für lang andauerndeWorkers, die ausgeführt werden, wenn einServiceim Vordergrund aktiv ist, besser verwalten. (aosp/1218539, b/147249312)
- WorkManagerist jetzt von- androidx.sqlite:sqlite-framework:2.1.0Stable abhängig. (aosp/1217729)
- Es wurden Lint-Regeln hinzugefügt, um sicherzustellen, dass ein foregroundServiceTypeimAndroidManifest.xmlangegeben ist, wennforegroundServiceTypes inForegroundInfoverwendet werden. (aosp/1214207, b/147873061)
Version 2.3.0
Version 2.3.0
22. Januar 2020
androidx.work:work-*:2.3.0 wird ohne Änderungen seit 2.3.0-rc01 veröffentlicht.  Version 2.3.0 enthält diese Commits.
Wichtige Änderungen seit Version 2.2.0
- Unterstützung für lang andauernde oder wichtige Aufgaben über ListenableWorker#setForegroundAsync().
- Unterstützung für den Worker-Fortschritt über ListenableWorker#setProgressAsync().
- WorkManager enthält jetzt zusätzliche Lint-Regeln als Teil der Bibliothek, mit denen Fehler frühzeitig erkannt werden können.
Version 2.3.0-rc01
8. Januar 2020
androidx.work:work-*:2.3.0-rc01 ist veröffentlicht.  Version 2.3.0-rc01 enthält diese Commits.
Dieser Release ist identisch mit 2.3.0-beta02
Fehlerkorrekturen
- Das work-testing-Artefakt definiert jetzt eineapi-Abhängigkeit vonwork-runtime-ktx. (aosp/1194410)
Version 2.3.0-beta02
18. Dezember 2019
androidx.work:work-*:2.3.0-beta02 ist veröffentlicht.  Version 2.3.0-beta02 enthält diese Commits.
Neue Funktionen
- Es wurde eine bessere Fehlermeldung für nicht behebungsfähige SQLite-Ausnahmen hinzugefügt. (aosp/1185777)
- Es wurde eine Lint-Regel hinzugefügt, die dafür sorgt, dass der Content-Provider androidx.work.impl.WorkManagerInitializerausAndroidManifest.xmlentfernt wird, wenn die On-Demand-Initialisierung verwendet wird. (aosp/1167007)
- Es wurde eine Lint-Warnung hinzugefügt, wenn enqueue()für einPeriodicWorkRequestanstelle vonenqueueUniquePeriodicWork()verwendet wird. (aosp/1166032)
API-Änderungen
- Bei ForegroundInfomüssen Sie jetzt dienotificationIdangeben, die bei Verwendung vonListenableWorker.setForegroundAsync()verwendet werden soll. Dies ist eine funktionsgefährdende Änderung. So können Sie mehrere lang laufendeWorkers parallel ausführen.WorkManagerverwaltet auch die Lebensdauer der bereitgestelltenNotifications besser. (b/145473554, aosp/1181208, asop/1181216, asop/1183577)
Fehlerkorrekturen
- Ein Fehler in der AlarmManager-Implementierung wurde behoben, bei dem Alarme nicht richtig bereinigt wurden. (aosp/1156444)
- Ein Fehler wurde behoben, durch den bei einer leeren Liste von WorkRequests eine falscheWorkContinuation-Kette erstellt wurde. (b/142835274, aosp/1157051)
Änderungen an Abhängigkeiten
- WorkManager verwendet jetzt Room 2.2.2.
Version 2.3.0-beta01
20. November 2019
androidx.work:work-*:2.3.0-beta01 ist veröffentlicht.  Version 2.3.0-beta01 enthält diese Commits.
Neue Funktionen
- Es wurde eine neue Lint-Regel hinzugefügt, die Entwicklerfehler aufgrund einer falschen Implementierung von androidx.work.Configuration.Providerbei Verwendung der On-Demand-Initialisierung verhindert. aosp/1164559
Version 2.3.0-alpha03
23. Oktober 2019
androidx.work:work-*:2.3.0-alpha03 ist veröffentlicht.  Version 2.3.0-alpha03 enthält diese Commits.
Neue Funktionen
- Die WorkManager.createCancelPendingIntent()API wurde hinzugefügt, mit der sichWorkRequests ganz einfach abbrechen lassen, ohne dass eine weitere Komponente in derAndroidManifest.xmlregistriert werden muss. Mit dieser API lassen sichWorkRequests besonders einfach überNotifications kündigen. Wir gehen davon aus, dass dies mit den neuen APIs für den Vordergrund in Version 2.3.0 einhergeht.
- WorkManager hängt jetzt von androidx.room:*:2.2.0ab.
API-Änderungen
- ForegroundInfo.getNotificationType()wurde in- ForegroundInfo.getForegroundServiceType()umbenannt, um besser mit den zugrunde liegenden Plattform-APIs übereinzustimmen. (b/142729893, aosp/1143316)
Fehlerkorrekturen
- Es wurde ein Fehler behoben, der durch einen unnötigen Aufruf von setTransactionSuccessful()außerhalb einer Transaktion verursacht wurde. Das passiert bei seltenen Migrationen. (b/142580433, aosp/1141737)
Version 2.3.0-alpha02
9. Oktober 2019
androidx.work:work-*:2.3.0-alpha02 ist veröffentlicht.  Version 2.3.0-alpha02 enthält diese Commits.
Neue Funktionen
- WorkManager unterstützt jetzt die Ausführung von zeitaufwendigen oder wichtigen Aufgaben, die vom Betriebssystem aktiv gehalten werden sollen. Weitere Informationen finden Sie unter ListenableWorker#setForegroundAsync()(oderCoroutineWorker#setForeground()für Kotlin). (aosp/1133636)
API-Änderungen
- Die containsKeyAPI inDatawurde inhasKeyWithValueOfTypeumbenannt. Die entsprechende Erweiterungsmethode in derktx-Bibliothek wurde ebenfalls umbenannt. (b/141916545)
Fehlerkorrekturen
- WorkManager plant Aufgaben fair, wenn sich die Anzahl der in die Warteschlange eingestellten WorkRequests den Planungslimits nähert. (aosp/1105766)
- WorkManager ruft ListenableWorker#onStopped()nur auf, wenn die Arbeit noch nicht abgeschlossen ist. (b/140055777)
- WorkManager entfernt jetzt Fortschrittsinformationen, wenn ein Worker unterbrochen wird oder seinen Endstatus erreicht. (aosp/1114572)
- Datahat jetzt eine viel nützlichere- toString()-Darstellung. (b/140945323)
- Databietet jetzt eine bessere- equals()-Methode. Außerdem wird- deepEqualsfür- Array-Typen unterstützt. (b/140922528)
- WorkManager speichert seine interne Datenbank und die Einstellungsdateien jetzt in einem Verzeichnis, das nicht gesichert wird. (b/114808216)
Version 2.3.0-alpha01
22. August 2019
androidx.work:work-*:2.3.September 5, 20190-alpha01 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Neue Funktionen
- ListenableWorkerkönnen jetzt den Fortschritt über die- setProgressAsync()API festlegen. Außerdem wurde in- CoroutineWorkereine entsprechende- suspend-ing- setProgressAPI und in- RxWorkerein- setProgresshinzugefügt, das ein- Single<Void>zurückgibt. Mit diesen neuen APIs können Worker Fortschrittsinformationen über- WorkInfoweitergeben, für die es eine entsprechende- getProgressAPI gibt. (b/79481554)
- Datahat eine- containsKey()-API, mit der sich prüfen lässt, ob die Eingabedaten für- Workers Schlüssel mit dem erwarteten Typ enthalten. (b/117136838)
- Datakann jetzt mit- Data.toByteArray()und- Data.fromByteArray()serialisiert werden. Beachten Sie, dass es für- Datakeine Versionsgarantien gibt. Sie sollten es daher nicht beibehalten oder für die IPC zwischen Anwendungen verwenden. Sie können nur zwischen mehreren Prozessen derselben Anwendung verwendet werden.
- Es ist jetzt möglich, eine InputMergerFactoryüberConfiguration.setInputMergerFactoryanzugeben. (b/133273159)
API-Änderungen
- WorkManager löst eine Instanz von IllegalStateExceptionaus, wenn einWorkerFactoryeine Instanz vonListenableWorkerzurückgibt, die zuvor aufgerufen wurde. (b/139554406)
- Dokumentationsupdates zur ListenableFuture-Kündigung und zumonStopped()-Callback inListenableWorker. (b/138413671)
Fehlerkorrekturen
- Der In-Process-Scheduler ignoriert jetzt WorkRequestmit der Einschränkungidle. Diese Anfragen werden jetzt nur noch vonJobSchedulererfasst, wenn das Gerät tatsächlichidleist. (aosp/1089779)
- TestSchedulerverwendet jetzt korrekt die angegebene- Executorfür die interne Aufgabenbearbeitung in Tests. (aosp/1090749)
Version 2.2.0
Version 2.2.0
15. August 2019
androidx.work:work-*:2.2.0 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Dieser Release ist mit androidx.work:work-*:2.2.0-rc01 identisch.
Wichtige Änderungen in Version 2.2.0 im Vergleich zu Version 2.1.0
androidx.work:work-gcm:2.2.0 ist ein neues Maven-Artefakt, das die Verwendung von GCMNetworkManager als Scheduler unterstützt, wenn Google Play-Dienste für API-Ebenen <= 22 verfügbar sind. Dies ist eine optionale Abhängigkeit, die für eine zuverlässigere und leistungsstärkere Hintergrundverarbeitung bei älteren API-Versionen sorgt. Wenn Ihre App Google Play-Dienste verwendet, fügen Sie Ihrer Gradle-Datei diese Abhängigkeit hinzu, um automatisch Unterstützung für GCMNetworkManager zu erhalten. Wenn die Play-Dienste nicht verfügbar sind, greift WorkManager auf älteren Geräten weiterhin auf AlarmManager zurück.
Version 2.2.0-rc01
30. Juli 2019
androidx.work:work-*:2.2.0-rc01 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Fehlerkorrekturen
- Ein Fehler in der AlarmManager-Implementierung wurde behoben, der dazu führte, dass der Dienst vorzeitig heruntergefahren wurde und in seltenen Fällen ein RejectedExecutionExceptionangezeigt wurde. (aosp/1092374) (b/138238197).
- Es wurde eine Problemumgehung für einen NullPointerExceptionbei der Verwendung vonJobScheduler-APIs auf einigen Geräten hinzugefügt. (aosp/1091020) (b/138364061), (b/138441699)
Version 2.2.0-beta02
19. Juli 2019
androidx.work:work-*:2.2.0-beta02 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Fehlerkorrekturen
- Die unbeabsichtigte jacoco-Abhängigkeit, die in 2.2.0-beta01eingeführt wurde, wurde entfernt.
Version 2.2.0-beta01
17. Juli 2019
androidx.work:work-*:2.2.0-beta01 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Neue Funktionen
- androidx.work:work-gcm:2.2.0-beta01ist ein neues Maven-Artefakt, das die Verwendung von GCMNetworkManager als Scheduler unterstützt, wenn Google Play-Dienste für API-Ebenen <= 22 verfügbar sind. Dies ist eine optionale Abhängigkeit, die für eine zuverlässigere und leistungsstärkere Hintergrundverarbeitung bei älteren API-Versionen sorgt. Wenn Ihre App Google Play-Dienste verwendet, fügen Sie Ihrer Gradle-Datei diese Abhängigkeit hinzu, um automatisch Unterstützung für GCMNetworkManager zu erhalten. Wenn die Play-Dienste nicht verfügbar sind, greift WorkManager auf älteren Geräten weiterhin auf AlarmManager zurück.
Fehlerkorrekturen
- Korrektur für IllegalArgumentExceptionbeim Erfassen des Netzwerkstatus auf Nvidia Shield K1-Tablets. (aosp/1010188)
Version 2.1.0
Version 2.1.0
11. Juli 2019
androidx.work:work-*:2.1.0 ist veröffentlicht. Dieser Release ist mit androidx.work:work-*:2.1.0-rc01 identisch.
Wichtige Änderungen seit Version 2.0.1
- work-runtime-ktxerfordert jetzt Java 8. Wenn Probleme auftreten, können Sie Ihrer- build.gradleFolgendes hinzufügen:- kotlinOptions { jvmTarget = "1.8" }
- Die On-Demand-Initialisierung für WorkManager wurde hinzugefügt. WorkManager wird nur erstellt, wenn darauf verwiesen wird.  b/127497100  So richten Sie Ihr Projekt für die On-Demand-Initialisierung ein:
- Automatischen Initialisierer deaktivieren
- Implementieren Sie Configuration.Providerfür Ihr benutzerdefiniertesApplication-Objekt.
- Ändern Sie alle Verweise auf WorkManager.getInstance()inWorkManager.getInstance(Context). Im Rahmen dieser Änderung haben wirWorkManager.getInstance()eingestellt. Es ist immer sicherer, den neuenWorkManager.getInstance(Context)-Ersatz aufzurufen, auch wenn Sie keine On-Demand-Initialisierung durchführen.
 
- PeriodicWorkRequests unterstützen jetzt anfängliche Verzögerungen. Mit der Methode- setInitialDelayin- PeriodicWorkRequest.Builderkönnen Sie eine anfängliche Verzögerung festlegen. b/111404867
- Es wurde die Möglichkeit hinzugefügt, die Berechtigung mit DelegatingWorkerFactoryan einen oder mehrere registrierteWorkerFactoryzu delegieren. b/131435993
- Es wurde die Möglichkeit hinzugefügt, die Executoranzupassen, die von WorkManager für alle internen Verwaltungsaufgaben überConfiguration.Builder.setTaskExecutorverwendet wird.
- Es wurde die Möglichkeit hinzugefügt, mithilfe von TestWorkerBuilderundTestListenableWorkerBuilderimwork-testing-ArtefaktWorker- undListenableWorker-Klassen zu erstellen, die sich für Unittests eignen.- work-testingzieht jetzt Kotlin als Abhängigkeit ein und enthält standardmäßig mehrere Kotlin-Erweiterungen.
 
- Die Anzahl der Ausführungsversuche wurde WorkInfohinzugefügt. b/127290461
- Data-Typen können jetzt Bytes und Byte-Arrays speichern und abrufen. Dadurch wird die maximale Größe von- Data-Objekten NICHT geändert.
- WorkManager hängt jetzt von Room 2.1.0ab, was einige Datenbankprobleme beheben sollte.
Version 2.1.0-rc01
27. Juni 2019
androidx.work:work-*:2.1.0-rc01 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Fehlerkorrekturen
- Ein Fehler wurde behoben, der dazu führte, dass eine Anwendung beim Ausführen von Jobs mit JobSchedulerabstürzte, während eine Sicherung lief b/135858602.
Version 2.1.0-beta02
20. Juni 2019
androidx.work:work-*:2.1.0-beta02 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Fehlerkorrekturen
- TestListenableWorkerBuilderverwendet jetzt die richtige- WorkerFactorybeim Erstellen von Instanzen von- ListenableWorker. b/135275844
- Ein Fehler wurde behoben, der aufgrund von Prozessbeendigung zu Abweichungen bei den Ausführungszeiträumen für WorkRequests geführt hat. b/135272196
Version 2.1.0-beta01
13. Juni 2019
androidx.work:work-*:2.1.0-beta01 ist veröffentlicht.  Die in dieser Version enthaltenen Commits finden Sie hier.
Fehlerkorrekturen
- WorkManager hängt jetzt von Room 2.1.0ab, was einige Datenbankprobleme beheben sollte.
- Einige E/A-Vorgänge der Startdisk wurden aus dem Hauptthread entfernt.
- Ein potenzieller Deadlock beim Constraint-Tracking wurde behoben. b/134361006
- Ungültige Jobs, die WorkManager zugeordnet sind, werden präventiv abgebrochen. b/134058261
- Es wurden einige defensive Aufrufe zu JobScheduler-APIs für Geräte mit Fehlverhalten hinzugefügt.
Version 2.1.0-alpha03
5. Juni 2019
androidx.work:*:2.1.0-alpha03 ist veröffentlicht.
Fehlerkorrekturen
- Verbesserte Dokumentation für PeriodicWorkRequest.
- WorkManagerTestInitHelperverwendet jetzt den richtigen Hintergrund-Executor für Tests.
- Es wurden Probleme mit SQLite behoben, die beim Umgang mit großen Transaktionen auf einigen Geräten auftreten konnten. (b/130182503)
- Die Abhängigkeiten von WorkManager sind jetzt detaillierter. (b/133169148).
- Umgang mit OEM-spezifischen Fehlern bei der Implementierung von JobSchedulerbeim Planen von Jobs mit WorkManager.
- Es wurden Verbesserungen am AlarmManager-basierten Scheduler vorgenommen, die zuvor seltene Abstürze verursacht haben. (b/133313734)
Version 2.1.0-alpha02
16. Mai 2019
WorkManager 2.1.0-alpha02 wurde veröffentlicht. Diese Version enthält mehrere neue APIs.
API-Änderungen
- PeriodicWorkRequests unterstützen jetzt anfängliche Verzögerungen. Mit der Methode- setInitialDelayin- PeriodicWorkRequest.Builderkönnen Sie eine anfängliche Verzögerung festlegen. b/111404867
- Es wurde die Möglichkeit hinzugefügt, die Berechtigung mit - DelegatingWorkerFactoryan einen oder mehrere registrierte- WorkerFactoryzu delegieren. b/131435993
- Es wurde die Möglichkeit hinzugefügt, die - Executoranzupassen, die von WorkManager für alle internen Verwaltungsaufgaben über- Configuration.Builder.setTaskExecutorverwendet wird.
- Die Dokumentation zu - WorkRequest.keepResultsForAtLeast(b/130638001), zur On-Demand-Initialisierung und zu- PeriodicWorkRequest.Builder(b/131711394) wurde verbessert.
Version 2.1.0-alpha01
24. April 2019
WorkManager 2.1.0-alpha01 wurde veröffentlicht. Diese Version enthält mehrere neue APIs. Ab dieser Version gibt es neue Funktionen, die nicht in die Version 1.x zurückportiert werden. Wir empfehlen, auf Version 2.x umzustellen.
API-Änderungen
- Die On-Demand-Initialisierung für WorkManager wurde hinzugefügt. WorkManager wird nur erstellt, wenn darauf verwiesen wird.  b/127497100  So richten Sie Ihr Projekt für die On-Demand-Initialisierung ein:
- Automatischen Initialisierer deaktivieren
- Implementieren Sie Configuration.Providerfür Ihr benutzerdefiniertesApplication-Objekt.
- Ändern Sie alle Verweise auf WorkManager.getInstance()inWorkManager.getInstance(Context). Im Rahmen dieser Änderung haben wirWorkManager.getInstance()eingestellt. Es ist immer sicherer, den neuenWorkManager.getInstance(Context)-Ersatz aufzurufen, auch wenn Sie keine On-Demand-Initialisierung durchführen.
 
- Es wurde die Möglichkeit hinzugefügt, mithilfe von TestWorkerBuilderundTestListenableWorkerBuilderimwork-testing-ArtefaktWorker- undListenableWorker-Klassen zu erstellen, die sich für Unittests eignen.- work-testingzieht jetzt Kotlin als Abhängigkeit ein, enthält aber auch standardmäßig mehrere Kotlin-Erweiterungen.
 
- Die Anzahl der Ausführungsversuche wurde WorkInfohinzugefügt. b/127290461
- Data-Typen können jetzt Bytes und Byte-Arrays speichern und abrufen. Dadurch wird die maximale Größe von- Data-Objekten NICHT geändert.
- CoroutineWorker.coroutineContextist veraltet. Dieses Feld wurde fälschlicherweise als- CoroutineDispatchertypisiert. Sie sollten es nicht mehr benötigen, da Sie im Hauptteil der suspend-Funktion selbst zum gewünschten „CoroutineContext“ wechseln können.
- RxWorker.createWork()und- RxWorker.getBackgroundScheduler()sind jetzt mit- @NonNull-Rückgabetypen annotiert.
Version 2.0.1
Version 2.0.1
9. April 2019
WorkManager 2.0.1 ist jetzt verfügbar. Dieser Release ist identisch mit 2.0.1-rc01.
Version 2.0.1-rc01
3. April 2019
WorkManager 2.0.1-rc01 ist jetzt verfügbar. Diese Version enthält einige Fehlerkorrekturen. Für Nutzer der alten Version 1.x sind einige dieser Änderungen auch in 1.0.1-rc01 enthalten.
Fehlerkorrekturen
- Robolectric-Tests funktionieren jetzt richtig mit WorkManager. b/122553577
- Ein seltener Absturz wurde behoben, der auftrat, wenn die Constraint-Verfolgung in APIs vor JobScheduler nicht bereinigt wurde. b/129226383
- Es wurde ein StackOverflowErrorbehoben, der sich auf lange Arbeitsketten bezog. b/129091233
- Die Dokumentation für PeriodicWorkRequestwurde aktualisiert, um darauf hinzuweisen, dass flexible Zeit unter API 23 nicht unterstützt wird.
- Einige fehlerhafte Links in der Kotlin-Dokumentation wurden korrigiert.
Version 2.0.0
Version 2.0.0
20. März 2019
WorkManager 2.0.0 ist jetzt verfügbar. Diese Version ist mit 2.0.0-rc01 identisch und ist die AndroidX-Version von 1.0.0 (stabil) mit AndroidX-Abhängigkeiten. Wir empfehlen, diese Version anstelle der Legacy-Versionen 1.x zu verwenden. Alle aktiven Entwicklungen zielen auf Version 2.x ab. Version 1.x erhält nur noch für begrenzte Zeit kritische Fehlerkorrekturen.
Version 2.0.0-rc01
7. März 2019
WorkManager 2.0.0-rc01 ist jetzt verfügbar. Diese Version ist identisch mit Version 1.0.0 (stabil), hat aber AndroidX-Abhängigkeiten. Sobald diese Version 2.0.0 erreicht hat, sollten Sie sie einbinden. Die Legacy-Versionen 1.x erhalten dann nur noch einige kritische Fehlerkorrekturen. Alle aktiven Entwicklungen zielen auf Version 2.x ab.
Abhängigkeiten vor AndroidX
Referenzdokumente: Java
Groovy
dependencies { def work_version = "1.0.1" // (Java only) implementation "android.arch.work:work-runtime:$work_version" // Kotlin + coroutines implementation "android.arch.work:work-runtime-ktx:$work_version" // optional - RxJava2 support implementation "android.arch.work:work-rxjava2:$work_version" // optional - Test helpers androidTestImplementation "android.arch.work:work-testing:$work_version" }
Kotlin
dependencies { val work_version = "1.0.1" // (Java only) implementation("android.arch.work:work-runtime:$work_version") // Kotlin + coroutines implementation("android.arch.work:work-runtime-ktx:$work_version") // optional - RxJava2 support implementation("android.arch.work:work-rxjava2:$work_version") // optional - Test helpers androidTestImplementation("android.arch.work:work-testing:$work_version") }
Version 1.0.1
Version 1.0.1
9. April 2019
WorkManager 1.0.1 ist jetzt verfügbar. Dieser Release ist identisch mit 1.0.1-rc01.
Wir empfehlen dringend, auf WorkManager 2.x zu aktualisieren, da es in Zukunft nur noch sehr wenige Updates für den 1.x-Zweig geben wird. Für die 1.x-Bibliothek werden auch keine neuen APIs veröffentlicht.
Version 1.0.1-rc01
2. April 2019
WorkManager 1.0.1-rc01 ist jetzt verfügbar. Diese Version enthält einige Fehlerkorrekturen.
Fehlerkorrekturen
- Robolectric-Tests funktionieren jetzt richtig mit WorkManager. b/122553577
- Ein seltener Absturz wurde behoben, der auftrat, wenn die Constraint-Verfolgung in APIs vor JobScheduler nicht bereinigt wurde. b/129226383
- Es wurde ein StackOverflowErrorbehoben, der sich auf lange Arbeitsketten bezog. b/129091233
Version 1.0.0
Version 1.0.0
5. März 2019
Dies ist die stabile Version 1.0.0 von WorkManager. Diese Version von WorkManager ist identisch mit Version 1.0.0-rc02.
Version 1.0.0-rc02
21. Februar 2019
Dies ist der zweite Releasekandidat für die stabile Version 1.0.0 von WorkManager. Diese Version enthält zwei Fehlerkorrekturen.
Fehlerkorrekturen
- Workerwerden jetzt nach einem Anwendungsabsturz korrekt geplant. b/124546316
- Worker, die eine ungeprüfte- Exceptionauslösen, werden jetzt korrekt als- FAILEDgekennzeichnet und führen nicht mehr zum Absturz des App-Prozesses.
Version 1.0.0-rc01
14. Februar 2019
Dies ist ein Release-Kandidat für die stabile Version 1.0.0 von WorkManager. Diese Version enthält eine Fehlerkorrektur.
Fehlerkorrekturen
- Die auf AlarmManager basierende Implementierung berücksichtigt jetzt flex-Zeiträume für PeriodicWorkRequests korrekt. b/124274584
Version 1.0.0-beta05
6. Februar 2019
Diese Version enthält einige Fehlerbehebungen.
Fehlerkorrekturen
- Ein Fehler wurde behoben, bei dem JobScheduler.getPendingJob(...)in API 23 verwendet wurde. b/123893059
- Ein NullPointerExceptionauf Geräten mit Android 5.1 (API-Level 22) oder niedriger wurde behoben. b/123835104
Version 1.0.0-beta04
4. Februar 2019
Diese Version enthält einige Fehlerbehebungen.
Fehlerkorrekturen
- Die Planung von PeriodicWork wurde für die AlarmManager-basierte Implementierung verbessert.
- Ein Problem wurde behoben, bei dem WorkManager Einschränkungen bei Verwendung der AlarmManager-basierten Implementierung nicht richtig verfolgt hat. b/123379508
- Es wurde ein Fall behoben, in dem WorkManager die Wiederholung von Aufgaben bei Prozessende nicht versucht hat, wenn die AlarmManager-basierte Implementierung verwendet wurde. b/123329850
- Ein Fall wurde behoben, der dazu führte, dass WorkManager bei Verwendung der AlarmManager-basierten Implementierung Wakelocks verlor.
Version 1.0.0-beta03
25. Januar 2019
Diese Version enthält einige Fehlerbehebungen.
Fehlerkorrekturen
- Wir haben eine Regression 1.0.0-beta02eingeführt, die dazu führte, dass Aufgaben in einigen Situationen nicht richtig ausgeführt wurden. b/123211993
- Ein Problem wurde behoben, bei dem die Backoff-Zeit nicht richtig berücksichtigt wurde. b/122881597
- Ein ConcurrentModificationExceptionauf Geräten mit Android 5.1 (API) oder niedriger wurde behoben. Dies ist eine Fortsetzung der Korrektur in1.0.0-beta02. b/121345393
- exported=falsewurde für einige Komponenten in unserem Manifest hinzugefügt, für die diese Annotation fehlte.
- Informationen zur Interaktion von WorkManager mit dem Betriebssystem sind in der Dokumentation auf Paketebene enthalten.
Version 1.0.0-beta02
15. Januar 2019
Diese Version enthält einige Fehlerbehebungen.
Fehlerkorrekturen
- Ein Grenzfall wurde behoben, in dem periodische Aufgaben auf Geräten mit Android 6.0 (API-Level 23) mehr als einmal pro Intervall ausgeführt werden konnten. b/121998363
- Ein ConcurrentModificationExceptionauf Geräten mit Android 5.1 (API-Level 22) oder niedriger wurde behoben. b/121345393
- Es wurde ein Fehler behoben, der dazu führte, dass Aufgaben fälschlicherweise ausgeführt wurden, wenn die Einschränkungen auf Geräten mit Android 5.1 (API-Level 22) oder niedriger nicht erfüllt waren. b/122578012
- Die Verarbeitung von abgeschlossenen Arbeitsvorgängen wurde optimiert, um in einigen Grenzfall-Szenarien schneller zu sein. b/122358129
- Es wurde eine Änderung hinzugefügt, um potenzielle Race-Bedingungen zwischen mehreren Instanzen von LiveDatazu beheben, die von WorkManager verwendet werden.
- Es wird jetzt die Room-Abhängigkeit1.1.1anstelle von1.1.1-rc01verwendet. Diese Versionen sind identisch. b/122578011
Version 1.0.0-beta01
19. Dezember 2018
Diese Version enthält keine API-Änderungen. WorkManager wird voraussichtlich bis zur nächsten Version API-stabil bleiben, sofern kein schwerwiegendes Problem auftritt. Diese Version enthält einige Fehlerbehebungen.
Fehlerkorrekturen
- Zuvor abgebrochene untergeordnete Jobs von erfolgreich abgeschlossenen übergeordneten Jobs werden nicht mehr ausgeführt. b/120811767
- Korrekt initialisierte Protokollierungsklassen (hauptsächlich bei Tests).
Version 1.0.0-alpha13
12. Dezember 2018
Dieser Release enthält eine geringfügige API-Änderung, die für einige Kotlin-Nutzer hilfreich sein wird.
API-Änderungen
- androidx.work.Resultwurde als innere Klasse von- ListenableWorkerverschoben. Dadurch werden Refactoring-Konflikte mit der- Result-Klasse auf oberster Ebene von Kotlin verhindert. Dies ist eine API-Änderung, die zu Inkompatibilitäten führen kann. b/120564418
Breaking API Changes
- androidx.work.Resultwurde als innere Klasse von- ListenableWorkerverschoben.
Version 1.0.0-alpha12
5. Dezember 2018
Dieses Release enthält einige funktionsgefährdende API-Änderungen. Weitere Informationen finden Sie unten im Abschnitt Funktionsgefährdende API-Änderungen.  Diese Version wird wahrscheinlich als unsere erste Betaversion veröffentlicht.  alpha12 enthält auch umfassende Dokumentationsaktualisierungen.
API-Änderungen
- Mit dem neuen Artefakt work-rxjava2wirdRxWorkereingeführt. Dies ist einListenableWorker, der einenSingle<Payload>erwartet.
- Die Unterstützung für Firebase JobDispatcher wurde aufgrund der bevorstehenden Einstellung entfernt.  Das bedeutet, dass das work-firebase-Artefakt nicht mehr aktualisiert wird, wenn wir in die Betaphase eintreten. Wir werden uns ansehen, ob wir in Zukunft eine Alternative anbieten können.
- Payloadmit- Resultzusammengeführt- Resultist jetzt eine „sealed class“ mit drei konkreten Implementierungen, die Sie über- Result.success()(oder- Result.success(Data)),- Result.failure()(oder- Result.failure(Data)) und- Result.retry()abrufen können. Ihre- ListenableFutureführen jetzt zu- Resultstatt zu- Payload.- Workers haben keine Getter- und Setter-Methoden für die Ausgabe- Data. Dies ist eine funktionsgefährdende Änderung.
- Constraints.Builder.setTriggerContentMaxDelay(long, TimeUnit)und- Constraints.Builder.setTriggerContentUpdateDelay(long, TimeUnit)sowie Varianten wurden hinzugefügt, um die Unterstützung von Inhalts-URIs mit langsamer Auslösung zu verbessern. b/119919774
- Variante WorkRequest.Builder.setBackoffCriteria(BackoffPolicy, Duration)hinzugefügt. Für diese Methode ist API 26 erforderlich.
- Die Kotlin-Erweiterungsmethoden Operation.await()undListenableFuture.await()wurden hinzugefügt.
- Operation.getException()wurde in- Operation.getThrowable()umbenannt. Dies ist eine funktionsgefährdende Änderung.
- Die Klasse ContentUriTriggersund die Methoden, die darauf verweisen, sind nicht mehr öffentlich verfügbar. Dies ist eine funktionsgefährdende Änderung.
- Die restlichen Varargs-Methoden in WorkManager,WorkContinuationundOneTimeWorkRequestwurden entfernt, um die API zu optimieren. Um Build-Probleme zu beheben, können Sie Ihre vorhandenen Varargs mitArrays.asList(...)umschließen. Wir behalten weiterhin Versionen jeder Methode mit einem einzelnen Argument bei. Dies ist eine funktionsgefährdende Änderung.
- WorkContinuation.combine(OneTimeWorkRequest, *)Varianten wurden entfernt. Die API war verwirrend. Die vorhandenen- combine-Methoden sind verständlicher. Dies ist eine funktionsgefährdende Änderung.
Fehlerkorrekturen
- Implementierungen vor Marshmallow sind jetzt zuverlässiger, wenn es darum geht, nach dem Beenden eines bereits ausgeführten Prozesses wiederherzustellen.
- LiveData, das über- observeForeverbeobachtet wird, wird über WorkManager erfasst. Dies ist ein Backport eines Room-Bibliotheks-Fix. b/74477406
- Data.Builder.build()löst jetzt eine Ausnahme aus, wenn das serialisierte Objekt die maximale Größe überschreitet. Bisher trat dies nur in einem Hintergrundthread auf, in dem Sie es nicht richtig verarbeiten konnten.
- Es wird zwischen beendeter und abgebrochener Arbeit unterschieden. getWorkInfoById()gibt währendListenableWorker.onStopped()einWorkInfomit demCANCELLEDStatezurück.
- Behandeln Sie nullResults als Fehler inListenableWorker. b/120362353
- Spekulativer Fix für Shield-Tablets mit API 24, die manchmal einen IllegalArgumentException-Fehler auslösten. b/119484416
Breaking API Changes
- Die Unterstützung für Firebase JobDispatcher wurde aufgrund der bevorstehenden Einstellung entfernt.  Das bedeutet, dass das work-firebase-Artefakt nicht mehr aktualisiert wird, wenn wir in die Betaphase eintreten. Wir werden uns ansehen, ob wir in Zukunft eine Alternative anbieten können.
- Payloadmit- Resultzusammengeführt- Resultist jetzt eine „sealed class“ mit drei konkreten Implementierungen, die Sie über- Result.success()(oder- Result.success(Data)),- Result.failure()(oder- Result.failure(Data)) und- Result.retry()abrufen können. Ihre- ListenableFutureführen jetzt zu- Resultstatt zu- Payload.- Workers haben keine Getter- und Setter-Methoden für die Ausgabe- Data.
- Die Kotlin-Erweiterungsmethoden Operation.await()undListenableFuture.await()wurden hinzugefügt.
- Operation.getException()wurde in- Operation.getThrowable()umbenannt.
- Die Klasse ContentUriTriggersund die Methoden, die darauf verweisen, sind nicht mehr öffentlich verfügbar.
- Die restlichen Varargs-Methoden in WorkManager,WorkContinuationundOneTimeWorkRequestwurden entfernt, um die API zu optimieren. Um Build-Probleme zu beheben, können Sie Ihre vorhandenen Varargs mitArrays.asList(...)umschließen. Wir behalten weiterhin Versionen jeder Methode mit einem einzelnen Argument bei.
- WorkContinuation.combine(OneTimeWorkRequest, *)Varianten wurden entfernt. Die API war verwirrend. Die vorhandenen- combine-Methoden sind verständlicher.
Version 1.0.0-alpha11
8. November 2018
Diese Version enthält viele Änderungen, die am beta zur stabilen API werden.
Diese Version enthält funktionsgefährdende API-Änderungen. Weitere Informationen finden Sie unten im Abschnitt Funktionsgefährdende API-Änderungen.
API-Änderungen
- Mit work-runtime-ktxwird ein neuerCoroutineWorkereingeführt.
- WorkStatuswurde in- WorkInfoumbenannt. Alle entsprechenden- getStatus-Methodenvarianten wurden in die entsprechenden- getWorkInfo-Varianten umbenannt. Dies ist eine funktionsgefährdende Änderung.
- ListenableWorker.onStopped()akzeptiert jetzt ein boolesches Argument, das angibt, ob- WorkRequestgekündigt wurde. Bei- WorkManagerwird diese Unterscheidung nicht mehr getroffen. Dies ist eine funktionsgefährdende Änderung.
- Das Paket androidx.work.testwurde inandroidx.work.testingumbenannt. Dies ist eine funktionsgefährdende Änderung.
- Setter für Constraintssind nicht mehr Teil der öffentlichen API. Dies ist eine funktionsgefährdende Änderung.
- WorkerParameters.getTriggeredContentUris()und- WorkerParameters.getTriggeredContentAuthorities()sind zuvor zurückgegebene Arrays. Diese Methoden geben jetzt Sammlungen zurück. Dies ist eine funktionsgefährdende Änderung.
- ListenableWorker.onStartWork()wird in- ListenableWorker.startWork()umbenannt. Dies ist eine funktionsgefährdende Änderung.
- Der Konstruktor für WorkStatusist nicht mehr Teil der öffentlichen API. Dies ist eine funktionsgefährdende Änderung.
- Configuration.getMaxJobSchedulerID()und- Configuration.getMinJobSchedulerID()werden in- Configuration.getMinJobSchedulerId()bzw.- Configuration.getMaxJobSchedulerId()umbenannt. Dies ist eine funktionsgefährdende Änderung.
- Der öffentlichen API wurden viele @NonNull-Annotationen hinzugefügt, um die Ergonomie der API zu verbessern.
- Fügen Sie die WorkManager.enqueueUniqueWork()API hinzu, um eindeutigeOneTimeWorkRequests in die Warteschlange zu stellen, ohne eineWorkContinuationerstellen zu müssen.
- Alle Varianten der Methoden enqueueundcancelfürWorkManagergeben jetzt einen neuen TypOperationzurück. Dies ist eine funktionsgefährdende Änderung.
- Alle Varianten von enqueueakzeptieren keine Varargs mehr fürWorkRequests. Dies ist eine funktionsgefährdende Änderung. Verwenden Sie stattdessen Sammlungen. MitArrays.asList()können Sie vorhandenen Code ändern. Wir haben dies getan, um die API-Oberfläche und die Anzahl der Methoden zu reduzieren.
- Der Versuch, initializeWorkManagermehr als einmal pro Prozess auszuführen, führt jetzt zu einemIllegalStateException. Dies ist eine funktionsgefährdende Änderung.
Fehlerkorrekturen
- WorkRequest.Builders im- work-runtime-ktx-Artefakt verwenden jetzt- ListenableWorkers. Behebt b/117666259
- Die nächste Ausführungszeit für PeriodicWorkmuss in der Zukunft liegen. Behebt b/118204399
- Potenzielle Laufwerk-E/A-Vorgänge bei der Verwendung von WorkManager beim Starten der App entfernen. Behebt b/117796731
- Eine Race-Bedingung in WorkConstraintsTrackerwurde behoben. Behebt android-workmanager/issues/56
Breaking API Changes
- WorkStatuswurde in- WorkInfoumbenannt. Alle entsprechenden- getStatus-Methodenvarianten wurden in die entsprechenden- getWorkInfo-Varianten umbenannt.
- ListenableWorker.onStopped()akzeptiert jetzt ein boolesches Argument, das angibt, ob- WorkRequestgekündigt wurde. Bei- WorkManagerwird diese Unterscheidung nicht mehr getroffen.
- Das Paket androidx.work.testwurde inandroidx.work.testingumbenannt.
- Setter für Constraintssind nicht mehr Teil der öffentlichen API.
- WorkerParameters.getTriggeredContentUris()und- WorkerParameters.getTriggeredContentAuthorities()sind zuvor zurückgegebene Arrays. Diese Methoden geben jetzt Sammlungen zurück.
- ListenableWorker.onStartWork()wird in- ListenableWorker.startWork()umbenannt.
- Der Konstruktor für WorkStatusist nicht mehr Teil der öffentlichen API.
- Configuration.getMaxJobSchedulerID()und- Configuration.getMinJobSchedulerID()werden in- Configuration.getMinJobSchedulerId()bzw.- Configuration.getMaxJobSchedulerId()umbenannt.
- Alle Varianten der Methoden enqueueundcancelfürWorkManagergeben jetzt einen neuen TypOperationzurück.
- Alle Varianten von enqueueakzeptieren keine Varargs mehr fürWorkRequests.
- Der Versuch, initializeWorkManagermehr als einmal pro Prozess auszuführen, führt jetzt zu einemIllegalStateException.
Version 1.0.0-alpha10
11. Oktober 2018
In diesem Release wird die entwicklergesteuerte asynchrone Arbeit unterstützt. Diese Version enthält funktionsgefährdende API-Änderungen. Weitere Informationen finden Sie unten im Abschnitt Funktionsgefährdende API-Änderungen.
WorkManager befindet sich voraussichtlich in der Endphase der Alphaperiode. Wir gehen davon aus, dass die API in der Betaphase stabil sein wird. Bitte nehmen Sie sich daher etwas Zeit, um uns Ihr Feedback über unseren Issue Tracker mitzuteilen.
API-Änderungen
- Alle zuvor deprecated-Methoden und -Klassen wurden entfernt, insbesondere der StandardkonstruktorWorker. Dies ist eine funktionsgefährdende API-Änderung.
- NonBlockingWorkerwurde in- ListenableWorkerumbenannt.- ListenableWorkerist jetzt eine nicht ausgeblendete öffentliche Klasse und kann verwendet werden.- ListenableWorkerbietet Zugriff auf eine abstrakte Methode,- ListenableFuture<Payload> onStartWork(), die im Hauptthread aufgerufen wird. Es liegt an Ihnen, die Arbeit asynchron zu starten und zu verarbeiten. Wenn Sie fertig sind, sollten Sie- ListenableFutureentsprechend aktualisieren. Referenzimplementierungen von- ListenableFutures sind im- Futures-Paket in- alpha02verfügbar (siehe unten im Abschnitt- WorkManager).
- Workererweitert- ListenableWorkerund funktioniert weiterhin wie bisher mit einer abstrakten- Result doWork()-Methode.
- Einige Methoden und Elemente wurden von WorkernachListenableWorkerverschoben.
- Wir werden demnächst Referenzimplementierungen für ListenableWorkers bereitstellen, die Kotlin-Coroutinen (sobald die stabilen Versionen veröffentlicht werden) und RxJava2 verwenden.
 
- Die Schnittstelle WorkerFactoryund die konkrete ImplementierungDefaultWorkerFactorywurden in einer abstrakten Klasse namensWorkerFactoryzusammengeführt. Die Implementierung sorgt dafür, dass das standardmäßige auf Reflexion basierende Verhalten als letzter Ausweg für alle vom Nutzer erstelltenWorkerFactory-Instanzen aufgerufen wird. Dies ist eine funktionsgefährdende Änderung.
- WorkManager.synchronous()und- WorkContinuation.synchronous()sowie alle zugehörigen Methoden wurden entfernt.- ListenableFuture<Void>wurde als Rückgabetyp vieler Methoden in der API hinzugefügt. Dies ist eine funktionsgefährdende API-Änderung.- Sie können jetzt synchron Daten abrufen und beobachten, indem Sie ListenableFutureverwenden.WorkManager.enqueue()hat beispielsweise frühervoidzurückgegeben, jetzt wird einListenableFuture<Void>zurückgegeben. Sie könnenListenableFuture.addListener(Runnable, Executor)oderListenableFuture.get()aufrufen, um Code auszuführen, sobald der Vorgang abgeschlossen ist.
- Beachten Sie, dass diese ListenableFutures nicht angeben, ob der Vorgang erfolgreich war oder fehlgeschlagen ist, sondern nur, dass er abgeschlossen wurde. Sie müssen weiterhin WorkManager-Methoden verketten, um diese Informationen zu erhalten.
- Wir ignorieren cancel()-Aufrufe für diese Objekte, da sie verwirrend und schwer nachzuvollziehen sind (wird der Vorgang oder das Ergebnis abgebrochen?). Dies ist im Vertrag vonFutureenthalten.
- Um die Parität mit den synchronen getStatus*-Methoden aufrechtzuerhalten, haben wirListenableFuture-Varianten bereitgestellt und die vorhandenen Methoden, dieLiveDatazurückgegeben haben, umbenannt, sodass „LiveData“ explizit im Namen enthalten ist (z. B.getStatusesByIdLiveData(UUID)). Dies ist eine API-Änderung, die zu Inkompatibilitäten führen kann.
 
- Sie können jetzt synchron Daten abrufen und beobachten, indem Sie 
Fehlerkorrekturen
- Das bekannte Problem aus Alpha09 in Bezug auf doppelte androidx-annotations.pro-Dateien wurde behoben. Sie können den Workaround aus den vorherigen Versionshinweisen entfernen, indem Sieexclude 'META-INF/proguard/androidx-annotations.pro'aus Ihrer Gradle-Datei löschen.
- Proguard-Konfigurationen hinzugefügt, um den neuen Worker-Konstruktor beizubehalten. b/116296569
- Mögliche NullPointerExceptionin einem Race Condition-Szenario behoben, in dem die ArbeitREPLACEwurde. b/116253486 und b/116677275
- WorkContinuation.combine()akzeptiert jetzt ein oder mehrere- WorkContinuations anstelle von mindestens zwei. b/117266752
Breaking API Changes
- Alle zuvor deprecated-Methoden und -Klassen wurden entfernt, insbesondere der StandardkonstruktorWorker.
- Die Schnittstelle WorkerFactoryund die konkrete ImplementierungDefaultWorkerFactorywurden in einer abstrakten Klasse namensWorkerFactoryzusammengeführt.
- WorkManager.synchronous()und- WorkContinuation.synchronous()wurden entfernt.
- WorkManager.getStatus*()-Methoden geben jetzt- ListenableFutures zurück.- WorkManager.getStatus*LiveData()gibt- LiveDatazurück.
Version 1.0.0-alpha09
19. September 2018
Bekanntes Problem
Wenn das folgende Problem auftritt: „More than one file was found with OS independent path 'META-INF/proguard/androidx-annotations.pro'“ (Es wurde mehr als eine Datei mit dem betriebssystemunabhängigen Pfad „META-INF/proguard/androidx-annotations.pro“ gefunden), fügen Sie bitte Folgendes in Ihre Gradle-Datei ein. Dies ist eine vorübergehende Problemumgehung, bis wir das Problem in Alpha 10 beheben:
Groovy
android { packagingOptions { exclude 'META-INF/proguard/androidx-annotations.pro' } }
Kotlin
android { packagingOptions { exclude("META-INF/proguard/androidx-annotations.pro") } }
Fehlerkorrekturen
- Eine weitere Korrektur für den Fehler „100 Jobs“ wurde hinzugefügt. b/115560696
- Es wurden einige Korrekturen für Fehler bei Fremdschlüsseleinschränkungen aufgrund von Race-Bedingungen hinzugefügt. b/114705286
- Delegierte ConstraintTrackingWorker.onStopped(boolean)-Aufrufe an die zugrunde liegendeWorker. b/114125093
- Die richtige Mindest-Backoff-Verzögerung für Firebase JobDispatcher wird erzwungen. b/113304626
- Verbesserte Threading-Garantien innerhalb der Bibliothek.
- Ein potenzielles Problem mit der internen Deduplizierung von LiveDatawurde behoben.
API-Änderungen
- Sie können jetzt eigene Worker-Instanzen zur Laufzeit erstellen, indem Sie einWorkerFactoryals Teil desWorkManager.Configurationangeben. Die Fallback-Factory istDefaultWorkerFactory, was dem Verhalten früherer Versionen von WorkManager entspricht.- Die Standardkonstruktoren für WorkerundNonBlockingWorkersind jetzt als veraltet markiert. Verwenden Sie den neuen Konstruktor (Worker(Context, WorkerParameters)) und rufen Siesuper(Context, WorkerParameters)auf. In zukünftigen Versionen von WorkManager wird der Standardkonstruktor entfernt.
 
- Die Standardkonstruktoren für 
- Wir verwenden das neue Artefakt ListenableFuture(ohne Guava-Abhängigkeiten) intern. Wir werden ListenableFutures in zukünftigen Versionen in die API einführen. Diese Änderung wird dazu beitragen, dassNonBlockingWorkerwieder sichtbar gemacht werden kann.
- Es wurde die Möglichkeit hinzugefügt, zeitgesteuerte Aufgaben in TestDriverüberTestDriver.setInitialDelayMet(UUID)undTestDriver.setPeriodDelayMet(UUID)auszulösen. b/113360060
Aktuelle Änderungen
- Die Standardkonstruktoren WorkerundNonBlockingWorkersind veraltet. Migrieren Sie so schnell wie möglich zum neuen Konstruktor. In zukünftigen Versionen wird der Standardkonstruktor entfernt.
Version 1.0.0-alpha08
27. August 2018
Fehlerkorrekturen
- WorkManager-Komponenten wurden explizit als „Direct Boot Unaware“ gekennzeichnet, damit sie nicht während des Direct Boot-Vorgangs gestartet werden. Künftig werden wir eine Version von WorkManager bereitstellen, die Direct Boot unterstützt. b/112665532
- Ein Problem wurde behoben, bei dem wiederholte Aufgaben nicht ausgeführt wurden. b/112604021
- Ein Problem wurde behoben, durch das periodische Aufgaben nicht wiederholt ausgeführt wurden (bezogen auf das oben genannte Problem). b/112859683
- Backoff-Richtlinien werden berücksichtigt, wenn der App-Prozess bereits ausgeführt wird.
- Die Fehlermeldungen in Datawurden korrigiert, um darauf hinzuweisen, dass das Limit 10 KB beträgt.
- Der Maximalwert von Configuration.setMaxSchedulerLimit(int)wurde auf 50 gesenkt, um eine gewisse Latenz bei der Verarbeitung vonJobSchedulerzu berücksichtigen. b/112817355
Version 1.0.0-alpha07
16. August 2018
Fehlerkorrekturen
- Es wurde ein potenzielles Problem mit SQL-Abfragen mit negativen Grenzwerten behoben, die eine unbegrenzte Anzahl von Ergebnissen zurückgeben konnten.
- Wenn die Ausführung einer Aufgabe abgeschlossen ist, werden jetzt alle ausstehenden Kopien dieser Aufgabe in anderen Schedulern korrekt abgebrochen. Dadurch wurde das Limit von JobSchedulerJobs überschritten. b/111569265
- Es wurde ein ConcurrentModificationExceptioninConstraintTrackerbehoben. b/112272753
- Die Rückgabetyp-Annotationen von Data.getBooleanArray(String)undData.getIntArray(String)wurden in@Nullableanstelle von@NonNullgeändert. b/112275229
API-Änderungen
- Workererbt jetzt von der neuen Klasse- NonBlockingWorker. Das hat keine Auswirkungen auf die aktuelle Nutzung. In Zukunft wird- NonBlockingWorkereine vollständig unterstützte Einheit für benutzerdefinierte Threading-Lösungen sein.
- Die Rückgabetyp-Annotationen von Data.getBooleanArray(String)undData.getIntArray(String)wurden in@Nullableanstelle von@NonNullgeändert. b/112275229
- Kotlin-Erweiterungen: Map.toWorkData()wurde eingestellt und einworkDataOf(vararg Pair<String, Any?>)auf oberster Ebene wurde hinzugefügt, um die Konsistenz mit vorhandenen APIs zu verbessern.
Version 1.0.0-alpha06
1. August 2018
Fehlerkorrekturen
- Datenbank-Sperre beim Planen von Aufgaben verhindern. b/111801342
- Ein Fehler wurde behoben, der dazu führte, dass PeriodicWorkim Doze-Modus nicht planmäßig ausgeführt wurde. b/111469837
- Ein Race-Bedingung beim Tracking von Einschränkungen wurde behoben, die zum Absturz von WorkManagergeführt hat. googlecodelabs/android-workmanager/issues/56
- Erstellen Sie eindeutige WorkRequests, wenn SieWorkRequest.Builder#build()verwenden. b/111408337
- Aktivieren Sie die Verwendung von RescheduleReceivernur, wennWorkRequests dies erfordern. b/111765853
Version 1.0.0-alpha05
24. Juli 2018
API-Änderungen
- WorkManager.getInstance()ist jetzt mit- @NonNullstatt mit- @Nullablegekennzeichnet. Wenn das Singleton bei manueller Initialisierung nicht richtig initialisiert wird, löst die Methode stattdessen eine- IllegalStateExceptionaus. Dies ist eine API-Änderung, die zu Inkompatibilitäten führen kann.
- Es wurde eine neue API, Configuration.Builder.setMinimumLoggingLevel(int), hinzugefügt, mit der die Ausführlichkeit von WorkManager gesteuert werden kann. Standardmäßig protokolliert WorkManagerLog.INFOund höher.
- Die Signatur von Data.getString()wurde geändert, sodass kein Standardwert mehr verwendet wird (implizitnull). Dies ist eine nicht abwärtskompatible API-Änderung.
- Einige Methoden, die nur für die interne Verwendung erforderlich sind, wurden als @hidegekennzeichnet. Dazu gehören derConstraints-Konstruktor,Data.toByteArray()undData.fromByteArray(byte[]). Dies ist eine funktionsgefährdende API-Änderung.
Fehlerkorrekturen
- WorkManager führt keine Aufgaben mehr in bekannten Fällen der automatischen Sicherung aus. Dies könnte zu einem Absturz geführt haben. b/110564377
- Das Problem, dass PeriodicWorkRequests bei Verwendung vonJobSchedulerdoppelt geplant wurden, wurde behoben. b/110798652
- Ein Problem wurde behoben, bei dem PeriodicWorkRequestnach dem Inaktivitätsmodus des Geräts nicht richtig ausgeführt wurden. b/111469837
- Ein Problem mit anfänglichen Verzögerungen bei der Verwendung von Firebase JobDispatcher wurde behoben. b/111141023
- Es wurden einige potenzielle Race Conditions und Timing-Probleme behoben.
- BroadcastReceivers, die nicht mehr benötigt wurden, wurden korrekt freigegeben.
- Die Leistung beim erneuten Planen wurde optimiert, wenn Apps nach dem erzwungenen Schließen neu gestartet werden.
- Ermöglicht, dass TestScheduler.setAllConstraintsMet(UUID)vor oder nach dem Einreihen des angegebenenWorkRequestaufgerufen wird. b/111238024
Aktuelle Änderungen
- WorkManager.getInstance()ist jetzt mit- @NonNullstatt mit- @Nullablegekennzeichnet.
- Die Signatur von Data.getString()wurde geändert, sodass kein Standardwert mehr verwendet wird (implizitnull).
- Einige Methoden, die nur für die interne Verwendung erforderlich sind, wurden als @hidegekennzeichnet. Dazu gehören derConstraints-Konstruktor,Data.toByteArray()undData.fromByteArray(byte[]).
Version 1.0.0-alpha04
26. Juni 2018
Fehlerkorrekturen
- PeriodicWorkRequestwerden jetzt bei Verwendung der- AlarmManager-basierten Implementierung korrekt neu geplant.
- Ein potenzieller ANR-Fehler wurde behoben, der beim Neuplanen aller Worker nach einem erzwungenen Stopp oder einem Neustart auftreten konnte. b/110507716
- Verschiedenen WorkManager-APIs wurden Anmerkungen zur Null-Zulässigkeit hinzugefügt. b/110344065
- Nicht abgefangene Ausnahmen protokollieren, die während der Worker-Ausführung auftreten. b/109900862
- Destruktive Datenbankmigrationen sind zulässig, wenn Sie zu einer älteren Version von WorkManager zurückkehren möchten. b/74633270
- Ein Migrationsabsturz beim Erstellen doppelter impliziter Tags wurde behoben. Dieses Problem ist sehr selten und trat nur auf, wenn Sie selbst dasselbe implizite Tag-Format verwendet haben.
Version 1.0.0-alpha03
19. Juni 2018
Fehlerkorrekturen
- Eine Race-Bedingung in der - AlarmManager-basierten Implementierung wurde behoben. b/80346526.
- Doppelte Jobs bei Verwendung von - JobSchedulernach einem Geräteneustart behoben.
- Jobs mit Content-URI-Triggern bleiben jetzt auch nach einem Neustart erhalten. b/80234744 
- Dokumentationsupdates. b/109827628, b/109758949, b/80230748 
- Ein Absturz beim erneuten Einreihen eines - WorkRequestwurde behoben. b/109572353.
- Es wurden Kotlin-Compilerwarnungen bei Verwendung der - work-runtime-ktx-Abhängigkeit behoben.
- WorkManager verwendet jetzt - Room-Version- 1.1.1-rc1.
API-Änderungen
- getStatusesSync()wurde hinzugefügt, die synchrone Version von- WorkContinuation.getStatuses().
- Workerkann zwischen einer vom Nutzer initiierten Kündigung und einem vom Betriebssystem angeforderten temporären Stopp unterscheiden.- Worker.isStopped()gibt- truezurück, wenn ein Stopp angefordert wurde.- Worker.isCancelled()gibt- truezurück, wenn die Aufgabe explizit abgebrochen wurde. b/79632247
- Unterstützung für JobParameters#getNetwork() auf API 28 hinzugefügt. Dies wird über Worker.getNetwork()bereitgestellt.
- Configuration.Builder.setMaxSchedulerLimit(int maxSchedulerLimit)wurde hinzugefügt, damit Sie erzwingen können, wie viele Jobs an- JobScheduleroder- AlarmManagergesendet werden können. So wird verhindert, dass- WorkManageralle verfügbaren- JobScheduler-Slots belegt.
- Es wurde Configuration.setJobSchedulerJobIdRange(int minJobSchedulerId, int maxJobSchedulerId)hinzugefügt, um einen Bereich vonJobScheduler-Job-IDs zu definieren, die fürWorkManagersicher sind. b/79996760
- Worker.getRunAttemptCount()gibt die aktuelle Anzahl der Ausführungen für eine bestimmte- Workerzurück. b/79716516
- Mit WorkManager.enqueueUniquePeriodicWork(String uniqueWorkName, ExistingPeriodicWorkPolicy existingPeriodicWorkPolicy, PeriodicWorkRequest periodicWork)können Sie eindeutigePeriodicWorkRequests in die Warteschlange stellen. b/79600647
- Mit WorkManager.cancelAllWork()werden alleWorker-Vorgänge abgebrochen. Bibliotheken, die vonWorkManagerabhängen, können mitWorkManager.getLastCancelAllTimeMillis()abfragen, wann diese Methode zuletzt aufgerufen wurde, um den internen Status zusätzlich zu bereinigen.
- WorkManager.pruneWork()wurde hinzugefügt, um abgeschlossene Jobs aus der internen Datenbank zu entfernen. b/79950952, b/109710758
Geändertes Verhalten
- Für alle WorkRequests wurde ein implizites Tag hinzugefügt. Das ist der voll qualifizierte Klassenname für dieWorker. So könnenWorkRequests ohnetags oder wenn dieidnicht verfügbar ist, entfernt werden. b/109572351
Aktuelle Änderungen
- Worker.WorkerResultwurde in- Worker.Resultumbenannt.
- Worker.onStoppedhat jetzt einen zusätzlichen- isCancelled-Parameter, der auf- truegesetzt wird, wenn das- Workerexplizit gekündigt wurde.
Version 1.0.0-alpha02
24. Mai 2018
Fehlerkorrekturen
- Es wurde ein NullPointerExceptionaufState.isFinished()behoben. b/79550068
- Ein Problem wurde behoben, das dazu führte, dass WorkeraufApplication.onCreate()verschoben wurden. b/79660657
- Ein Problem wurde behoben, bei dem mehr Arbeit geplant werden konnte, als vom Betriebssystem zulässig ist. b/79497378
- Die Bereinigung von Wake Locks, die mit Workerverknüpft sind, wurde in den Hintergrundthread verschoben.
- Die AlarmManager-Implementierung wird jetzt korrekt bereinigt, wenn alle ausstehenden Arbeiten abgeschlossen sind.
- Es wurden SQL-Bereinigungsabfragen korrigiert, die sich auf nicht englischsprachige Gebiete auswirkten. b/80065360
- Unterstützung für floats inDatahinzugefügt. b/79443878
- Data.Builder.putAll()gibt jetzt eine Instanz von- Builderzurück. b/79699162
- Mehr Javadoc und Korrekturen in der Dokumentation. b/79691663
API-Änderungen
- Workerkönnen darauf reagieren, dass sie angehalten werden. Mit- Worker.isStopped()kann geprüft werden, ob ein- Workerbeendet wurde. Mit- Worker.onStopped()können einfache Bereinigungsvorgänge ausgeführt werden.
- Die Worker.getTags()API gibt einSetmit Tags zurück, die mit demWorkerverknüpft sind.
- javax.time.Duration-Überladungen für APIs hinzugefügt, die eine Kombination aus Dauer und- TimeUnits verwenden. Dies wird durch- @RequiresApi(26)geschützt.
- WorkManager-Erweiterungen wurden vom- androidx.work.ktx-Paket in das- androidx.work-Paket verschoben. Die alten Erweiterungen sind veraltet und werden in einer zukünftigen Version entfernt.
- Configuration.withExecutor()ist veraltet. Verwenden Sie stattdessen- Configuration.setExecutor().
Version 1.0.0-alpha01
8. Mai 2018
WorkManager vereinfacht die Planung und Ausführung von garantierten, einschränkungsbewussten Hintergrundaufgaben. Diese erste Version ist 1.0.0-alpha01.
