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

Unter Android 14 kann das System Kontextregistrierte Broadcasts in eine Warteschlange stellen, während die App sich im Cache-Status befindet. Das ähnelt der Warteschlangenfunktion Verhalten, das mit Android 12 (API-Level 31) für asynchrones Binden eingeführt wurde Transaktionen. Manifestdeklarierte Broadcasts werden nicht in die Warteschlange gestellt und Apps entfernt aus dem Cache-Status für die Übertragung.

Wenn die App den Cache-Status verlässt und z. B. zum Vordergrund zurückkehrt, Broadcasts in der Warteschlange. Mehrere Instanzen bestimmter Broadcasts zu einer Übertragung zusammengeführt werden. Je nach anderen Faktoren wie dem Systemstatus werden Apps möglicherweise aus dem Cache entfernt und alle zuvor in der Warteschlange befindlichen Übertragungen werden gesendet.

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

Wenn Nutzern in deiner App Benachrichtigungen im Vordergrund angezeigt werden, die sich nicht schließen lassen, gilt für Android 14 das Verhalten geändert, sodass Nutzer solche Benachrichtigungen schließen können.

Diese Änderung gilt für Apps, die Nutzer daran hindern, den Vordergrund zu schließen Benachrichtigungen erhalten, indem Sie Notification.FLAG_ONGOING_EVENT bis Notification.Builder#setOngoing(true) oder NotificationCompat.Builder#setOngoing(true) Das Verhalten von FLAG_ONGOING_EVENT wurde geändert, damit solche Benachrichtigungen vom Nutzer tatsächlich geschlossen werden können.

Solche Benachrichtigungen lassen sich auch in folgenden Fällen nicht schließen: Bedingungen:

  • Wenn das Smartphone gesperrt ist
  • Wenn der Nutzer die Benachrichtigungsaktion Alle löschen auswählt. Dies hilft bei versehentliche Ablehnungen)

Außerdem gilt dieses neue Verhalten nicht für Benachrichtigungen im folgende Anwendungsfälle:

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

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

Starting with Android 14, apps with a targetSdkVersion lower than 23 can't be installed. Requiring apps to meet these minimum target API level requirements improves security and privacy for users.

Malware often targets older API levels in order to bypass security and privacy protections that have been introduced in newer Android versions. For example, some malware apps use a targetSdkVersion of 22 to avoid being subjected to the runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API level 23). This Android 14 change makes it harder for malware to avoid security and privacy improvements. Attempting to install an app targeting a lower API level will result in an installation failure, with the following message appearing in Logcat:

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

On devices upgrading to Android 14, any apps with a targetSdkVersion lower than 23 will remain installed.

If you need to test an app targeting an older API level, use the following ADB command:

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

Paketnamen von Mediainhabern 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