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
testen Sie Ihre App und passen Sie sie bei Bedarf an, um diese korrekt zu unterstützen.
zutreffend sind.
Sehen Sie sich auch die Liste der Verhaltensänderungen an, die nur Apps betreffen auf Android 14 ausgerichtet ist.
Hauptfunktion
Das Planen von genauen Weckern ist standardmäßig nicht zulässig
精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 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 für den ersten GATT-Client, der eine MTU anfordert, auf 517 festgelegt.
从 Android 14 开始,Android 蓝牙堆栈会更严格地遵循 蓝牙核心规范 5.2 版,并在第一个 GATT 客户端使用 BluetoothGatt#requestMtu(int)
API 请求 MTU 时将 BLE ATT MTU 请求设为 517 字节,并忽略该 ACL 连接上的所有后续 MTU 请求。
如需解决此更改并使您的应用更为稳健,请考虑以下选项:
- 您的外围设备应使用外围设备可以容纳的合理值来响应 Android 设备的 MTU 请求。最终协商的值将是 Android 请求的值和远程提供的值(例如
min(517, remoteMtu)
)的较小值- 实现此修复程序可能需要更新外围设备的固件
- 或者,您也可以根据外围设备的已知支持值与收到的 MTU 更改值之间的最小值来限制 GATT 特征写入
- 提醒您,应将标头的支持大小减小 5 个字节
- 例如:
arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5
Neuer Grund, warum eine Anwendung in den 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.
Das System erzwingt die Ressourcennutzung für im Cache gespeicherte Apps
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
Nutzererfahrung
Änderungen an der Darstellung von Benachrichtigungen, die sich nicht schließen lassen
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
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 Schriftgrößenänderung von bis zu 200 %. So erhalten sehbehinderte Nutzer zusätzliche Optionen für Barrierefreiheit, die den Richtlinien für barrierefreie Webinhalte (Web Content Accessibility Guidelines, WCAG) entsprechen.
Wenn Sie bereits skalierte Pixel (sp) als Einheiten für die 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 unterstützt, ohne dass die Nutzerfreundlichkeit beeinträchtigt wird.
Sicherheit
Minimales installierbares Ziel-API-Level
Ab Android 14 werden Apps mit einem
targetSdkVersion
: niedriger als 23
kann nicht installiert werden. Durch die Anforderung, dass Apps diese Mindestanforderungen an das Ziel-API-Level erfüllen müssen, wird die Sicherheit und der Datenschutz für Nutzer verbessert.
Malware zielt häufig auf ältere API-Level ab, um Sicherheit und Datenschutz zu umgehen
die in neueren Android-Versionen eingeführt wurden. Beispiel:
einige Malware-Apps einen targetSdkVersion
von 22, um zu verhindern, dass sie
2015 durch Android 6.0 Marshmallow (API) eingeführtes Laufzeitberechtigungsmodell
Stufe 23). Durch diese Android 14-Änderung wird es Malware schwerer, Sicherheitsrisiken zu umgehen
und Verbesserungen beim Datenschutz.
Der Versuch, eine App zu installieren, die auf ein niedrigeres API-Level ausgerichtet ist, führt zu einem Installationsfehler. In Logcat wird die folgende Meldung angezeigt:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
Auf Geräten mit einem Upgrade auf Android 14: alle Apps mit einem um targetSdkVersion
niedrigeren
als 23 installiert bleiben.
Wenn du eine App testen musst, die auf ein älteres API-Level ausgerichtet ist, verwende den folgenden ADB-Code Befehl:
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 如何出于隐私保护目的而过滤软件包可见性。