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

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 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

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

System erzwingt Ressourcennutzung für Apps im Cache

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

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

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

Nutzererfahrung

Änderungen bei nicht schließbaren Benachrichtigungen

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

Informationen zur Datensicherheit sind besser sichtbar

Um den Datenschutz für Nutzer zu verbessern, werden in Android 14 mehr Stellen hinzugefügt, an denen das System die Informationen anzeigt, die Sie im Play Console-Formular angegeben haben. Derzeit können Nutzer diese Informationen im Abschnitt Datensicherheit im Store-Eintrag Ihrer App bei Google Play einsehen.

Wir empfehlen Ihnen, die Richtlinien zur Weitergabe von Standortdaten Ihrer App zu prüfen und gegebenenfalls die erforderlichen Änderungen am Abschnitt zur Datensicherheit von Google Play vorzunehmen.

Weitere Informationen dazu, wie Informationen zur Datensicherheit unter Android 14 besser sichtbar sind, finden Sie im Leitfaden.

Bedienungshilfen

Nicht lineare Skalierung der Schriftgröße auf 200%

从 Android 14 开始,系统支持将字体放大至最高 200%,为用户提供更多无障碍选项。

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

Sicherheit

Mindest-API-Level für die Installation

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

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

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

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