Verhaltensänderungen: alle Apps

Die Android 14-Plattform umfasst Verhaltensänderungen, die sich auf Ihre App auswirken können. Die folgenden Änderungen gelten für alle Apps, wenn sie unter Android 14 ausgeführt werden, unabhängig von targetSdkVersion. Sie sollten Ihre Anwendung testen und dann bei Bedarf so ändern, dass sie ordnungsgemäß unterstützt wird.

Sieh dir unbedingt auch die Liste der Änderungen des Verhaltens, die sich nur auf Apps auswirken, die auf Android 14 ausgerichtet sind an.

Hauptfunktion

„Genaue Alarme festlegen“ werden standardmäßig abgelehnt

Exakte Alarme sind für vom Nutzer beabsichtigte Benachrichtigungen oder für Aktionen gedacht, die zu einem bestimmten Zeitpunkt ausgelöst werden müssen. Ab Android 14 wird die Berechtigung SCHEDULE_EXACT_ALARM den meisten neu installierten Apps, die auf Android 13 und höher ausgerichtet sind, nicht mehr vorab gewährt. Sie wird standardmäßig verweigert.

Weitere Informationen zu den Änderungen an der Berechtigung für die Planung exakter Alarme

Kontextregistrierte Broadcasts werden in die Warteschlange gestellt, während Apps im Cache gespeichert werden

Unter Android 14 kann das System kontextregistrierte Broadcasts in eine Warteschlange stellen, während sich die App im Cache-Status befindet. Dies ähnelt dem Warteschlangenverhalten, das Android 12 (API-Level 31) für asynchrone Binder-Transaktionen eingeführt hat. Vom Manifest deklarierte Broadcasts werden nicht in die Warteschlange gestellt und Apps werden für die Übermittlung von Broadcasts aus dem Cache-Status entfernt.

Wenn die App den Cache-Status verlässt, z. B. in den Vordergrund zurückkehrt, sendet das System alle in der Warteschlange befindlichen Broadcasts. Mehrere Instanzen bestimmter Broadcasts können zu einer Übertragung zusammengeführt werden. Abhängig von anderen Faktoren, wie dem Systemzustand, können Anwendungen aus dem Cache-Status entfernt und alle zuvor in die Warteschlange gestellten Übertragungen zugestellt werden.

Apps können nur ihre eigenen Hintergrundprozesse beenden

Wenn deine App ab Android 14 killBackgroundProcesses() aufruft, kann die API nur die Hintergrundprozesse deiner eigenen App beenden.

Wenn Sie den Paketnamen einer anderen Anwendung übergeben, hat diese Methode keine Auswirkungen auf die Hintergrundprozesse dieser Anwendung. In Logcat wird dann die folgende Meldung angezeigt:

Invalid packageName: com.example.anotherapp

Ihre App darf die killBackgroundProcesses() API nicht verwenden und auch nicht anderweitig versuchen, den Prozesslebenszyklus anderer Apps zu beeinflussen, auch nicht bei älteren Betriebssystemversionen. Unter Android bleiben im Cache gespeicherte Apps im Hintergrund und beendet sie automatisch, wenn das System Arbeitsspeicher benötigt. Wenn Ihre App andere Apps unnötigerweise beendet, kann sie die Systemleistung verringern und den Akkuverbrauch erhöhen, da diese Apps später vollständig neu gestartet werden müssen. Dadurch werden deutlich mehr Ressourcen benötigt als die Nutzung einer vorhandenen im Cache gespeicherten App.

MTU ist für den ersten GATT-Client, der eine MTU anfordert, auf 517 gesetzt

Ab Android 14 hält der Android-Bluetooth-Stack Version 5.2 der Bluetooth Core-Spezifikation strenger ein und fordert die BLE-ATT-MTU auf 517 Byte an, wenn der erste GATT-Client eine MTU mit der BluetoothGatt#requestMtu(int) API anfordert. Alle nachfolgenden MTU-Anfragen für diese ACL-Verbindung werden ignoriert.

Ziehen Sie die folgenden Optionen in Betracht, um auf diese Änderung zu reagieren und Ihre Anwendung robuster zu machen:

  • Ihr Peripheriegerät sollte auf die MTU-Anfrage des Android-Geräts mit einem angemessenen Wert antworten, der vom Peripheriegerät akzeptiert werden kann. Der endgültig ausgehandelte Wert ist ein Minimum aus dem von Android angeforderten Wert und dem Remote-Wert (z. B. min(517, remoteMtu)).
    • Die Implementierung dieser Fehlerkorrektur erfordert möglicherweise ein Firmware-Update für die Peripheriegeräte
  • Alternativ können Sie die Schreibvorgänge für die GATT-Eigenschaft auf dem Mindestwert zwischen dem bekannten unterstützten Wert Ihres Peripheriegeräts und der empfangenen MTU-Änderung begrenzen.
    • Eine Erinnerung, dass Sie von der unterstützten Größe für die Header 5 Byte reduzieren sollten
    • Beispiel: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Neuer Grund, warum eine Anwendung in den eingeschränkten Standby-Bucket aufgenommen werden kann

In Android 14 gibt es einen neuen Grund für die Aufnahme von Apps in den eingeschränkten Stand-by-Bucket. Die Jobs der Anwendung lösen aufgrund von Zeitüberschreitungen für die Methoden onStartJob, onStopJob oder onBind mehrmals ANR-Fehler aus. Weitere Informationen zu Änderungen an onStartJob und onStopJob findest du unter JobScheduler verstärkt das Callback und Netzwerkverhalten.

Wenn Sie feststellen möchten, ob die Anwendung in den eingeschränkten Standby-Bucket gelangt ist, empfehlen wir, ein Logging mit der API UsageStatsManager.getAppStandbyBucket() bei der Jobausführung oder UsageStatsManager.queryEventsForSelf() beim Start der Anwendung zu verwenden.

mlock begrenzt auf 64 KB

In Android 14 (API-Level 34) und höher reduziert die Plattform den maximalen Arbeitsspeicher, der mit mlock() gesperrt werden kann, auf 64 KB pro Prozess. In früheren Versionen betrug das Limit 64 MB pro Prozess. Diese Einschränkung ermöglicht eine bessere Speicherverwaltung in Apps und im System. Um geräteübergreifend mehr Konsistenz zu bieten, wird mit Android 14 ein neuer CTS-Test für das neue Limit von mlock() auf kompatiblen Geräten hinzugefügt.

Das System erzwingt die Ressourcennutzung von im Cache gespeicherten Apps

Standardmäßig befindet sich ein Prozess einer App im Cache-Zustand, wenn sie in den Hintergrund verschoben wird und keine anderen Anwendungsprozesskomponenten ausgeführt werden. Ein solcher Anwendungsprozess wird aufgrund einer Auslastung des Systemspeichers beendet. Alle Vorgänge, die Activity-Instanzen ausführen, nachdem die Methode onStop() aufgerufen und zurückgegeben wurde, während sie sich in diesem Status befinden, sind unzuverlässig und raten dringend davon ab.

Android 14 sorgt für Konsistenz und Erzwingung für dieses Design. Kurz nachdem ein Anwendungsprozess in einen Cache-Status übergegangen ist, wird die Hintergrundarbeit unzulässig, bis eine Prozesskomponente wieder in den aktiven Status des Lebenszyklus wechselt.

Anwendungen, die typische vom Framework unterstützte Lebenszyklus-APIs verwenden, wie services, JobScheduler und Jetpack WorkManager, sollten von diesen Änderungen nicht betroffen sein.

Nutzererfahrung

Änderungen bei der Darstellung von Benachrichtigungen, die sich nicht schließen lassen

Wenn in deiner App Nutzern nicht schließbare Benachrichtigungen im Vordergrund angezeigt werden, wurde das Verhalten in Android 14 so geändert, dass Nutzer solche Benachrichtigungen schließen können.

Diese Änderung gilt für Apps, die verhindern, dass Nutzer Benachrichtigungen im Vordergrund schließen, indem sie Notification.FLAG_ONGOING_EVENT über Notification.Builder#setOngoing(true) oder NotificationCompat.Builder#setOngoing(true) festlegen. Das Verhalten von FLAG_ONGOING_EVENT wurde geändert, sodass solche Benachrichtigungen tatsächlich vom Nutzer geschlossen werden können.

Unter folgenden Bedingungen können solche Benachrichtigungen weiterhin nicht geschlossen werden:

  • Wenn das Smartphone gesperrt ist
  • Wenn der Nutzer die Benachrichtigungsaktion Alle löschen auswählt (was bei versehentlichem Schließen hilfreich ist)

Außerdem gilt das neue Verhalten in den folgenden Anwendungsfällen nicht für Benachrichtigungen:

  • CallStyle Benachrichtigungen
  • Device Policy Controller (DPC) und Supportpakete für Unternehmen
  • Medienbenachrichtigungen
  • Das Standardpaket für die Suchauswahl

Informationen zur Datensicherheit sind besser sichtbar

Aus Datenschutzgründen erhöht Android 14 die Anzahl der Orte, an denen das System die Informationen anzeigt, die du im Play Console-Formular angegeben hast. Derzeit können Nutzer diese Informationen im Abschnitt Datensicherheit des App-Eintrags bei Google Play einsehen.

Wir empfehlen Ihnen, die Richtlinien zur Weitergabe von Standortdaten Ihrer App zu lesen und den Abschnitt zur Datensicherheit bei Google Play gegebenenfalls anzupassen.

Weitere Informationen finden Sie im Leitfaden dazu, wie Informationen zur Datensicherheit unter Android 14 besser sichtbar werden.

Barrierefreiheit

Nicht lineare Schriftskalierung auf 200%

Ab Android 14 unterstützt das System eine Schriftskalierung von bis zu 200 % und bietet Nutzern mit eingeschränktem Sehvermögen zusätzliche Optionen für Bedienungshilfen, die den Richtlinien für barrierefreie Webinhalte (Web Content Accessibility Guidelines, WCAG) entsprechen.

Wenn Sie bereits skalierte Pixeleinheiten (sp) zur Definition der Textgröße verwenden, hat diese Änderung wahrscheinlich keine großen Auswirkungen auf Ihre Anwendung. Sie sollten jedoch UI-Tests mit aktivierter maximaler Schriftgröße (200%) durchführen, um sicherzustellen, dass Ihre Anwendung größere Schriftgrößen unterstützt, ohne die Nutzerfreundlichkeit zu beeinträchtigen.

Sicherheit

Minimales Ziel-API-Level für Installation

Ab Android 14 können Apps mit einem targetSdkVersion unter 23 nicht mehr installiert werden. Wenn Anwendungen die Mindestanforderungen an das Ziel-API-Level erfüllen, verbessern Sie die Sicherheit und den Datenschutz für Nutzer.

Malware zielt häufig auf ältere API-Levels ab, um die in neueren Android-Versionen eingeführten Sicherheits- und Datenschutzmaßnahmen zu umgehen. Bei einigen Malware-Apps wird beispielsweise für targetSdkVersion der Wert 22 verwendet, damit sie nicht dem 2015 von Android 6.0 Marshmallow (API-Level 23) eingeführten Laufzeitberechtigungsmodell unterliegen. Durch diese Änderung bei Android 14 wird es Malware schwerer, Verbesserungen bei der Sicherheit und beim Datenschutz zu vermeiden. Wenn Sie versuchen, eine App zu installieren, die auf eine niedrigere API-Ebene ausgerichtet ist, tritt bei der Installation ein Fehler auf. Außerdem wird die folgende Meldung in Logcat angezeigt:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7

Auf Geräten, die auf Android 14 aktualisiert werden, bleiben alle Apps mit einer targetSdkVersion unter 23 installiert.

Wenn Sie eine App testen müssen, die auf ein älteres API-Level ausgerichtet ist, verwenden Sie den folgenden ADB-Befehl:

adb install --bypass-low-target-sdk-block FILENAME.apk

Paketnamen von Medieninhabern werden möglicherweise entfernt

Der Medienspeicher unterstützt Abfragen für die Spalte OWNER_PACKAGE_NAME, die die App angibt, in der eine bestimmte Mediendatei gespeichert ist. Ab Android 14 wird dieser Wert entfernt, sofern nicht mindestens eine der folgenden Bedingungen erfüllt ist:

  • Die App, in der die Mediendatei gespeichert ist, hat einen Paketnamen, der für andere Apps immer sichtbar ist.
  • Die App, die den Medienspeicher abfragt, fordert die Berechtigung QUERY_ALL_PACKAGES an.

Weitere Informationen dazu, wie Android die Sichtbarkeit von Paketen aus Datenschutzgründen filtert