La plate-forme Android 14 apporte des modifications de comportement susceptibles d'affecter votre application. Les modifications de comportement suivantes s'appliquent à toutes les applications lorsqu'elles s'exécutent sur Android 14, peu importe la targetSdkVersion
. Vous devez tester votre application, puis la modifier si nécessaire afin de prendre en charge ces modifications, le cas échéant.
Veillez également à consulter la liste des modifications de comportement qui n'affectent que les applications ciblant Android 14.
Fonctionnalité de base
Les alarmes exactes programmées sont refusées par défaut
Les alarmes exactes sont destinées aux notifications ou aux actions intentionnelles de l'utilisateur qui doivent se produire à une heure précise. À partir d'Android 14, l'autorisation SCHEDULE_EXACT_ALARM
n'est plus disponible pour la plupart des applications récemment installées sur Android 13 ou version ultérieure. L'autorisation est refusée par défaut.
En savoir plus sur les modifications apportées aux autorisations de planification d'alarmes exactes
Les annonces diffusées en contexte sont mises en file d'attente pendant que les applications sont mises en cache.
在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。
当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。
Les applications ne peuvent fermer que leurs propres processus en arrière-plan
À partir d'Android 14, lorsque votre application appelle killBackgroundProcesses()
, seuls les processus en arrière-plan de votre propre application peuvent être fermés par l'API.
Si vous transmettez le nom de package d'une autre application, cette méthode n'a aucun effet sur les processus en arrière-plan de cette application et le message suivant s'affiche dans Logcat :
Invalid packageName: com.example.anotherapp
Votre application ne doit pas utiliser l'API killBackgroundProcesses()
ni tenter d'influencer le cycle de vie d'autres applications, même sur des versions d'OS plus anciennes.
Android est conçu pour conserver les applications mises en cache en arrière-plan et les fermer automatiquement lorsque le système a besoin de mémoire. Si votre application ferme d'autres applications de manière inutile, elle peut réduire les performances du système et augmenter la consommation de la batterie en exigeant un redémarrage complet de ces applications par la suite, ce qui nécessite beaucoup plus de ressources que la réactivation d'une application existante mise en cache.
La MTU est définie sur 517 pour le premier client GATT qui demande une MTU.
从 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
Nouveau motif pour lequel une application peut être placée dans le bucket de secours restreint
Android 14 introduit une nouvelle raison pour laquelle une application peut être placée dans le bucket en veille limitée.
Les tâches de l'application déclenchent des erreurs ANR à plusieurs reprises en raison des délais avant expiration des méthodes onStartJob
, onStopJob
ou onBind
.
Pour en savoir plus sur les modifications apportées à onStartJob
et onStopJob
, consultez la section JobScheduler renforce le comportement de rappel et du réseau.
Pour savoir si l'application est passée ou non dans le bucket de mise en veille limitée, nous vous recommandons de vous connecter avec l'API UsageStatsManager.getAppStandbyBucket()
lors de l'exécution de la tâche ou UsageStatsManager.queryEventsForSelf()
au démarrage de l'application.
mlock limité à 64 Ko
Sous Android 14 (niveau d'API 34) ou version ultérieure, la plate-forme réduit la mémoire maximale pouvant être verrouillée à l'aide de mlock()
à 64 Ko par processus. Dans les versions précédentes, la limite était de 64 Mo par processus. Cette restriction favorise une meilleure gestion de la mémoire dans les applications et le système. Pour améliorer la cohérence entre les appareils, Android 14 ajoute un nouveau test CTS pour la nouvelle limite de mlock()
sur les appareils compatibles.
Le système applique l'utilisation des ressources des applications mises en cache
Dès la conception, le processus d'une application est mis en cache lorsqu'elle est déplacée en arrière-plan et qu'aucun autre composant de processus d'application n'est en cours d'exécution. Un tel processus d'application peut être fermé en raison de la pression de la mémoire système. Tout travail effectué par les instances Activity
après l'appel et le retour de la méthode onStop()
est, dans cet état, peu fiable et fortement déconseillé.
Android 14 introduit une conception cohérente et appliquée. Peu de temps après qu'un processus d'application soit à l'état mis en cache, le travail en arrière-plan est interdit, jusqu'à ce qu'un composant de processus passe à nouveau à un état actif du cycle de vie.
Les applications qui utilisent des API de cycle de vie compatibles avec le framework, telles que services, JobScheduler
et Jetpack WorkManager, ne doivent pas être impactées par ces modifications.
Expérience utilisateur
Modifications apportées à la façon dont les utilisateurs gèrent les notifications qu'ils ne peuvent pas ignorer
Si votre application affiche des notifications au premier plan que les utilisateurs peuvent ignorer, Android 14 a changé leur comportement pour permettre aux utilisateurs d'ignorer ces notifications.
Cette modification s'applique aux applications qui empêchent les utilisateurs d'ignorer les notifications de premier plan en définissant Notification.FLAG_ONGOING_EVENT
à l'aide de Notification.Builder#setOngoing(true)
ou NotificationCompat.Builder#setOngoing(true)
. Le comportement de FLAG_ONGOING_EVENT
a été modifié afin que l'utilisateur puisse ignorer ces notifications.
Vous ne pouvez pas ignorer ces types de notifications dans les conditions suivantes :
- Lorsque le téléphone est verrouillé
- Si l'utilisateur sélectionne une action de notification Tout effacer (ce qui facilite la fermeture accidentelle)
Ce nouveau comportement ne s'applique pas non plus aux notifications les cas d'utilisation suivants:
- Notifications
CallStyle
- Outil de contrôle des règles relatives aux appareils (DPC) et packages compatibles pour les entreprises
- Notifications multimédias
- Package Search Selector par défaut
Amélioration de la visibilité des informations sur la sécurité des données
Pour améliorer la confidentialité des utilisateurs, Android 14 augmente le nombre d'emplacements sur lesquels le système affiche les informations que vous avez déclarées dans le formulaire de la Play Console. Actuellement, les utilisateurs peuvent consulter ces informations dans la section Sécurité des données de la fiche de votre application sur Google Play.
Nous vous invitons à consulter les règles relatives au partage des données de localisation de votre application et à mettre à jour la section Sécurité des données de Google Play de votre application.
Pour en savoir plus, consultez le guide sur la façon dont la visibilité des informations sur la sécurité des données a été améliorée sur Android 14.
Accessibilité
Mise à l'échelle non linéaire de la police à 200 %
À partir d'Android 14, le système prend en charge la mise à l'échelle des polices jusqu'à 200 %, offrant ainsi aux utilisateurs déficients visuels des options d'accessibilité supplémentaires qui respectent les consignes d'accessibilité du contenu Web (WCAG).
Si vous utilisez déjà des unités de pixels mis à l'échelle pour définir la taille du texte, cette modification n'aura probablement pas d'impact notable sur votre application. Toutefois, vous devez effectuer des tests de l'interface utilisateur en activant la taille de police maximale (200 %) pour vous assurer que votre application peut s'adapter à des tailles de police plus importantes sans nuire à la facilité d'utilisation.
Sécurité
Niveau d'API cible installable minimal
À partir d'Android 14, il est impossible d'installer des applications avec une targetSdkVersion
inférieure à 23. Demander aux applications de répondre à ces exigences minimales de niveau d'API cible améliore la sécurité et la confidentialité pour les utilisateurs.
Les logiciels malveillants ciblent souvent les anciens niveaux d'API afin de contourner les mesures de sécurité et de protection de la confidentialité introduites dans les nouvelles versions d'Android. Par exemple, certaines applications de logiciel malveillant utilisent une targetSdkVersion
de 22 pour éviter d'être soumises au modèle d'autorisation d'exécution introduit en 2015 par Android 6.0 Marshmallow (niveau d'API 23). Cette modification d'Android 14 rend plus difficile pour les logiciels malveillants de contourner les améliorations de sécurité et de confidentialité.
Si vous tentez d'installer une application ciblant un niveau d'API inférieur, l'installation échouera et le message suivant apparaîtra dans Logcat :
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
Sur les appareils passant à Android 14, les applications dont la version de targetSdkVersion
est inférieure à 23 restent installées.
Si vous devez tester une application ciblant un niveau d'API plus ancien, utilisez la commande ADB suivante :
adb install --bypass-low-target-sdk-block FILENAME.apk
Les noms de package du propriétaire média peuvent être masqués
Le Media Store accepte les requêtes pour la colonne OWNER_PACKAGE_NAME
, qui indique l'application qui a stocké un fichier multimédia spécifique. À partir d'Android 14, cette valeur sera masquée, sauf si au moins l'une des conditions suivantes est remplie :
- Le nom de package de l'application qui a stocké le fichier multimédia est toujours visible par les autres applications.
L'application qui interroge le Media Store demande l'autorisation
QUERY_ALL_PACKAGES
.
Découvrez comment Android filtre la visibilité des packages à des fins de confidentialité.