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
Genaue Wecker sind für Benachrichtigungen gedacht, die vom Nutzer gewünscht werden, oder für Aktionen, die zu einer bestimmten Zeit ausgeführt werden müssen. Ab Android 14 wird die Berechtigung SCHEDULE_EXACT_ALARM nicht mehr vorab für die meisten neu installierten Apps gewährt, die auf Android 13 und höher ausgerichtet sind. Die Berechtigung wird standardmäßig abgelehnt.
Weitere Informationen zu den Änderungen an der Berechtigung zum Planen von genauen Weckern
Kontextregistrierte Broadcasts werden in die Warteschlange gestellt, während Apps im Cache gespeichert werden
On Android 14, the system can place context-registered broadcasts in a queue while the app is in the cached state. This is similar to the queuing behavior that Android 12 (API level 31) introduced for async binder transactions. Manifest-declared broadcasts aren't queued, and apps are removed from the cached state for broadcast delivery.
When the app leaves the cached state, such as returning to the foreground, the system delivers any queued broadcasts. Multiple instances of certain broadcasts might be merged into one broadcast. Depending on other factors, such as system health, apps might be removed from the cached state, and any previously queued broadcasts are delivered.
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.
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 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
Gemäß dem Design befindet sich der Prozess einer App im Cache-Status, wenn er in den Hintergrund verschoben wird und keine anderen App-Prozesskomponenten ausgeführt werden. Ein solcher App-Prozess kann aufgrund von Speichermangel im System beendet werden. Jegliche Arbeit, die Activity-Instanzen in diesem Status ausführen, nachdem die onStop()-Methode aufgerufen und zurückgegeben wurde, ist unzuverlässig und wird dringend abgeraten.
Android 14 führt Konsistenz und Durchsetzung dieses Designs ein. Kurz nachdem ein App-Prozess in den Cache-Status wechselt, sind Hintergrundarbeiten nicht mehr zulässig, bis eine Prozesskomponente wieder in einen aktiven Status des Lebenszyklus übergeht.
Apps, die typische vom Framework unterstützte Lebenszyklus-APIs verwenden, z. B. services, JobScheduler und Jetpack WorkManager, sollten von diesen Änderungen nicht betroffen sein.
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
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 如何出于隐私保护目的而过滤软件包可见性。