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. Sie sollten Ihre App testen und sie gegebenenfalls so anpassen, dass sie diese Funktionen unterstützt.

Lesen Sie sich auch die Liste der Verhaltensänderungen durch, die sich nur auf Apps auswirken, 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

Ab Android 14 kann die API, wenn Ihre App killBackgroundProcesses() aufruft, nur die Hintergrundprozesse Ihrer eigenen App beenden.

Wenn Sie den Paketnamen einer anderen App übergeben, hat diese Methode keine Auswirkungen auf und die folgende Meldung wird in Logcat 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. Android ist darauf ausgelegt, im Cache gespeicherte Apps im Hintergrund zu speichern und zu beenden. automatisch, wenn das System Arbeitsspeicher benötigt. Wenn Ihre App andere Apps beendet kann unnötigerweise die Systemleistung verringern und den Akkuverbrauch erhöhen. da diese Apps später vollständig neu gestartet werden müssen, als beim Fortsetzen einer im Cache gespeicherten Anwendung.

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

Starting from Android 14, the Android Bluetooth stack more strictly adheres to Version 5.2 of the Bluetooth Core Specification and requests the BLE ATT MTU to 517 bytes when the first GATT client requests an MTU using the BluetoothGatt#requestMtu(int) API, and disregards all subsequent MTU requests on that ACL connection.

To address this change and make your app more robust, consider the following options:

  • Your peripheral device should respond to the Android device's MTU request with a reasonable value that can be accommodated by the peripheral. The final negotiated value will be a minimum of the Android requested value and the remote provided value (for example, min(517, remoteMtu))
    • Implementing this fix could require a firmware update for peripheral
  • Alternatively, limit your GATT characteristic writes based on the minimum between the known supported value of your peripheral and the received MTU change
    • A reminder that you should reduce 5 bytes from the supported size for the headers
    • For example: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Neuer Grund, warum eine App in den Bucket „Eingeschränkter Standby“ verschoben 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 auf 64 KB begrenzt

在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock() 锁定的最大内存减少为每个进程 64 KB。在以前的版本中,每个进程的大小上限为 64 MB。此限制可促进跨应用和系统更好地管理内存。为了提高各设备之间的一致性,Android 14 针对兼容设备上的新 mlock() 限制添加了新的 CTS 测试

Das System erzwingt die Ressourcennutzung für im Cache gespeicherte 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 nicht abwählbaren Benachrichtigungen

如果您的应用向用户显示不可关闭的前台通知,请注意:Android 14 已更改此行为,允许用户关闭此类通知。

这项变更适用于阻止用户关闭前台的应用 将 Notification.FLAG_ONGOING_EVENT 设置为 Notification.Builder#setOngoing(true)NotificationCompat.Builder#setOngoing(true)FLAG_ONGOING_EVENT 的行为已发生变化,使用户实际上能够关闭此类通知。

在以下情况下,此类通知仍不可关闭:

  • 当手机处于锁定状态时
  • 如果用户选择全部清除通知操作(有助于防止意外关闭)

此外,这一新行为不适用于以下用例中的通知:

  • CallStyle 条通知
  • 企业设备政策控制器 (DPC) 和支持软件包
  • 媒体通知
  • 默认的搜索选择器软件包

Bessere Sichtbarkeit von Informationen zur Datensicherheit

为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。

我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。

如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。

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

Mindest-API-Level, das installiert werden kann

从 Android 14 开始,targetSdkVersion 低于 23 的应用无法安装。要求应用满足这些最低目标 API 级别要求有助于提高用户的安全性和隐私性。

恶意软件通常会以较旧的 API 级别为目标平台,以绕过在较新版本 Android 中引入的安全和隐私保护机制。例如,有些恶意软件应用使用 targetSdkVersion 22,以避免受到 Android 6.0 Marshmallow(API 级别 23)在 2015 年引入的运行时权限模型的约束。这项 Android 14 变更使恶意软件更难以规避安全和隐私权方面的改进限制。尝试安装以较低 API 级别为目标平台的应用将导致安装失败,并且 Logcat 中会显示以下消息:

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

在升级到 Android 14 的设备上,targetSdkVersion 低于 23 的所有应用都将继续保持安装状态。

如果您需要测试以旧版 API 级别为目标平台的应用,请使用以下 ADB 命令:

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