Verhaltensänderungen: alle Apps

Die Android 14-Plattform umfasst Verhaltensänderungen, die sich auf Ihre App auswirken können. Die folgenden Verhaltensänderungen gelten für alle Apps, die unter Android 14 ausgeführt werden, unabhängig von targetSdkVersion. Du solltest deine Anwendung testen und dann bei Bedarf anpassen, damit sie korrekt unterstützt werden.

Sieh dir auch die Liste der Verhaltensänderungen an, die nur Apps betreffen, die auf Android 14 ausgerichtet sind.

Hauptfunktion

Genaue Alarme programmieren, werden standardmäßig verweigert

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

On Android 14, the system can place context-registered broadcasts in a queue while the app is in the cached state. This is similar to the queuing behavior that Android 12 (API level 31) introduced for async binder transactions. Manifest-declared broadcasts aren't queued, and apps are removed from the cached state for broadcast delivery.

When the app leaves the cached state, such as returning to the foreground, the system delivers any queued broadcasts. Multiple instances of certain broadcasts might be merged into one broadcast. Depending on other factors, such as system health, apps might be removed from the cached state, and any previously queued broadcasts are delivered.

Apps können nur ihre eigenen Hintergrundprozesse beenden

Starting in Android 14, when your app calls killBackgroundProcesses(), the API can kill only the background processes of your own app.

If you pass in the package name of another app, this method has no effect on that app's background processes, and the following message appears in Logcat:

Invalid packageName: com.example.anotherapp

Your app shouldn't use the killBackgroundProcesses() API or otherwise attempt to influence the process lifecycle of other apps, even on older OS versions. Android is designed to keep cached apps in the background and kill them automatically when the system needs memory. If your app kills other apps unnecessarily, it can reduce system performance and increase battery consumption by requiring full restarts of those apps later, which takes significantly more resources than resuming an existing cached app.

Die MTU wird für den ersten GATT-Client, der eine MTU anfordert, auf 517 eingestellt.

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 platziert 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 beschränkt 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.

System erzwingt die Nutzung von im Cache gespeicherten App-Ressourcen

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 an der Darstellung von Benachrichtigungen, die sich nicht schließen lassen

If your app shows non-dismissable foreground notifications to users, Android 14 has changed the behavior to allow users to dismiss such notifications.

This change applies to apps that prevent users from dismissing foreground notifications by setting Notification.FLAG_ONGOING_EVENT through Notification.Builder#setOngoing(true) or NotificationCompat.Builder#setOngoing(true). The behavior of FLAG_ONGOING_EVENT has changed to make such notifications actually dismissable by the user.

These kinds of notifications are still non-dismissable in the following conditions:

  • When the phone is locked
  • If the user selects a Clear all notification action (which helps with accidental dismissals)

Also, this new behavior doesn't apply to notifications in the following use cases:

  • CallStyle notifications
  • Device policy controller (DPC) and supporting packages for enterprise
  • Media notifications
  • The default Search Selector package

Bessere Sichtbarkeit von Informationen zur Datensicherheit

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.

Bedienungshilfen

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 installierbares Ziel-API-Level

Ab Android 14 werden Apps mit einem targetSdkVersion: niedriger als 23 kann nicht installiert werden. Apps müssen dieses minimale Ziel-API-Level erfüllen verbessern die Sicherheit und den Datenschutz für die Nutzer.

Malware zielt häufig auf ältere API-Level ab, um Sicherheit und Datenschutz zu umgehen die in neueren Android-Versionen eingeführt wurden. Beispiel: einige Malware-Apps einen targetSdkVersion von 22, um zu verhindern, dass sie 2015 durch Android 6.0 Marshmallow (API) eingeführtes Laufzeitberechtigungsmodell Stufe 23). Durch diese Android 14-Änderung wird es Malware schwerer, Sicherheitsrisiken zu umgehen und Verbesserungen beim Datenschutz. Der Versuch, eine App zu installieren, die auf eine niedrigere API-Ebene ausgerichtet ist, führt zu einer Installationsfehler. In Logcat wird folgende Meldung angezeigt:

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

Auf Geräten mit einem Upgrade auf Android 14: alle Apps mit einem um targetSdkVersion niedrigeren als 23 installiert bleiben.

Wenn du eine App testen musst, die auf ein älteres API-Level ausgerichtet ist, verwende den folgenden ADB-Code Befehl:

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

Paketnamen von Mediainhabern werden möglicherweise entfernt

The media store supports queries for the OWNER_PACKAGE_NAME column, which indicates the app that stored a particular media file. Starting in Android 14, this value is redacted unless at least one of the following conditions is true:

  • The app that stored the media file has a package name that is always visible to other apps.
  • The app that queries the media store requests the QUERY_ALL_PACKAGES permission.

Learn more about how Android filters package visibility for privacy purposes.