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, wenn sie unter Android 14 ausgeführt werden, unabhängig von targetSdkVersion. Sie sollten Ihre App testen und sie bei Bedarf anpassen, um diese richtig zu unterstützen.

Sehen Sie sich auch die Liste der Verhaltensänderungen an, die sich nur auf Apps auswirken, die auf Android 14 ausgerichtet sind.

Hauptfunktion

Das Planen exakter Alarme wird 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 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

从 Android 14 开始,当您的应用调用 killBackgroundProcesses() 时,该 API 只能终止您自己应用的后台进程。

如果您传入另一个应用的软件包名称,此方法对该应用的后台进程没有影响,并且 Logcat 中会显示以下消息:

Invalid packageName: com.example.anotherapp

您的应用不应使用 killBackgroundProcesses() API,也不得以其他方式尝试影响其他应用的进程生命周期,即使在旧版操作系统上也是如此。Android 旨在让缓存应用在后台运行,并在系统需要内存时自动终止它们。如果您的应用会不必要地终止其他应用,则由于之后需要完全重启这些应用,因此可能会降低系统性能并增加耗电量,这比恢复现有缓存应用所消耗的资源要多得多。

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

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

Um diese Änderung zu berücksichtigen und Ihre App robuster zu machen, haben Sie folgende Möglichkeiten:

  • Ihr Peripheriegerät sollte auf die MTU-Anfrage des Android-Geräts mit einem angemessenen Wert antworten, der vom Peripheriegerät unterstützt wird. Der endgültig ausgehandelte Wert ist mindestens der von Android angeforderte Wert und der vom Remote-Gerät bereitgestellte Wert (z. B. min(517, remoteMtu)).
    • Für die Implementierung dieser Fehlerbehebung ist möglicherweise ein Firmwareupdate für das Peripheriegerät erforderlich.
  • Alternativ können Sie die GATT-Attributschreibungen auf das Minimum zwischen dem bekannten unterstützten Wert Ihres Peripheriegeräts und der empfangenen MTU-Änderung beschränken.
    • Zur Erinnerung: Sie sollten die unterstützte Größe für die Überschriften um 5 Byte reduzieren.
    • Beispiel: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Neuer Grund, warum eine App im eingeschränkten Standby-Bucket platziert werden kann

In Android 14 gibt es einen neuen Grund, warum eine App in den eingeschränkten Standby-Bucket verschoben werden kann. Die Jobs der App lösen aufgrund von Zeitüberschreitungen der Methoden onStartJob, onStopJob oder onBind mehrmals ANR-Fehler aus. Weitere Informationen zu den Änderungen an onStartJob und onStopJob finden Sie unter JobScheduler verstärkt Rückruf- und Netzwerkverhalten.

Wenn Sie nachverfolgen möchten, ob die App den eingeschränkten Standby-Bucket betreten hat, empfehlen wir, bei der Jobausführung mit der API UsageStatsManager.getAppStandbyBucket() oder beim Starten der App mit UsageStatsManager.queryEventsForSelf() zu loggen.

mlock auf 64 KB begrenzt

Unter 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 trägt zu einer besseren Arbeitsspeicherverwaltung in Apps und im System bei. Für mehr Gerätekonsistenz wird in Android 14 ein neuer CTS-Test für die neue mlock()-Grenze für kompatible Geräte hinzugefügt.

System erzwingt Ressourcennutzung für Apps im Cache

从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity 实例在调用并返回 onStop() 方法后执行的任何工作均不可靠,强烈建议不要这样做。

Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。

使用框架支持的典型生命周期 API(例如服务JobSchedulerJetpack WorkManager)的应用应该不受这些变化的影响。

Nutzererfahrung

Änderungen bei nicht schließbaren Benachrichtigungen

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

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

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

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

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

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

Informationen zur Datensicherheit sind besser sichtbar

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

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

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

Bedienungshilfen

Nicht lineare Skalierung der Schriftgröße auf 200%

Ab Android 14 unterstützt das System die Schriftartskalierung auf bis zu 200 % und bietet Nutzern so zusätzliche Optionen für die Barrierefreiheit.

Wenn Sie bereits skalierbare Pixel (sp) zum Definieren der Textgröße verwenden, hat diese Änderung wahrscheinlich keine großen Auswirkungen auf Ihre App. Sie sollten jedoch UI-Tests mit aktivierter maximaler Schriftgröße (200%) durchführen, um sicherzustellen, dass Ihre App größere Schriftgrößen ohne Beeinträchtigung der Nutzerfreundlichkeit unterstützt.

Sicherheit

Mindest-API-Level für die 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 如何出于隐私保护目的而过滤软件包可见性