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 Ihre App testen und sie gegebenenfalls so anpassen, dass sie diese Funktionen unterstützt.
Lesen Sie sich auch die Liste der Verhaltensänderungen durch, die sich nur auf Apps auswirken, die auf Android 14 ausgerichtet sind.
Hauptfunktion
Genaue Alarme programmieren, werden standardmäßig verweigert
Exakte Alarme sind für vom Nutzer beabsichtigte Benachrichtigungen oder für Aktionen gedacht, die zu einem bestimmten Zeitpunkt ausgelöst werden müssen. Ab Android 14 wird die Berechtigung SCHEDULE_EXACT_ALARM
den meisten neu installierten Apps, die auf Android 13 und höher ausgerichtet sind, nicht mehr vorab gewährt. Sie wird standardmäßig verweigert.
Weitere Informationen zu den Änderungen an der Berechtigung für die Planung exakter Alarme
Kontextregistrierte Broadcasts werden in die Warteschlange gestellt, während Apps im Cache gespeichert werden
在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。
当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。
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.
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 App in den Bucket „Eingeschränkter Standby“ verschoben 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 auf 64 KB begrenzt
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 für im Cache gespeicherte Apps
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
Nutzererfahrung
Änderungen bei nicht abwählbaren 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
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 Schriftskalierung von bis zu 200 % und bietet Nutzern mit eingeschränktem Sehvermögen zusätzliche Optionen für Bedienungshilfen, die den Richtlinien für barrierefreie Webinhalte (Web Content Accessibility Guidelines, WCAG) entsprechen.
Wenn Sie bereits skalierte Pixeleinheiten (sp) zur Definition der Textgröße verwenden, hat diese Änderung wahrscheinlich keine großen Auswirkungen auf Ihre Anwendung. Sie sollten jedoch UI-Tests mit aktivierter maximaler Schriftgröße (200%) durchführen, um sicherzustellen, dass Ihre Anwendung größere Schriftgrößen unterstützt, ohne die Nutzerfreundlichkeit zu beeinträchtigen.
Sicherheit
Mindest-API-Level, das installiert werden kann
从 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 Mediainhabern werden möglicherweise entfernt
媒体库支持查询 OWNER_PACKAGE_NAME
列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:
- 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
查询媒体库的应用会请求
QUERY_ALL_PACKAGES
权限。
详细了解 Android 如何出于隐私保护目的而过滤软件包可见性。