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

精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM 权限,该权限默认处于拒绝状态。

详细了解安排精确闹钟的权限变化

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

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

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

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

Bedienungshilfen

Nicht lineare Schriftskalierung auf 200%

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。

Sicherheit

Minimales Ziel-API-Level für Installation

从 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 Medieninhabern werden möglicherweise entfernt

媒体库支持查询 OWNER_PACKAGE_NAME 列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:

  • 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
  • 查询媒体库的应用会请求 QUERY_ALL_PACKAGES 权限。

详细了解 Android 如何出于隐私保护目的而过滤软件包可见性