Changements de comportement : toutes les applications

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

精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM 权限,该权限默认处于拒绝状态。

详细了解安排精确闹钟的权限变化

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.

À partir d'Android 14, la pile Bluetooth Android respecte plus strictement la version 5.2 de la spécification de base Bluetooth et demande que la MTU ATT BLE soit définie sur 517 octets lorsque le premier client GATT demande une MTU à l'aide de l'API BluetoothGatt#requestMtu(int), et ignore toutes les requêtes MTU ultérieures sur cette connexion ACL.

Pour faire face à cette modification et rendre votre application plus robuste, envisagez les options suivantes:

  • Votre appareil périphérique doit répondre à la requête MTU de l'appareil Android avec une valeur raisonnable pouvant être prise en charge par le périphérique. La valeur finale négociée correspondra au minimum de la valeur demandée par Android et de la valeur fournie à distance (par exemple, min(517, remoteMtu)).
    • La mise en œuvre de ce correctif peut nécessiter une mise à jour du micrologiciel du périphérique.
  • Vous pouvez également limiter les écritures de la caractéristique GATT en fonction de la valeur minimale entre la valeur compatible connue de votre périphérique et la modification de l'MTU reçue.
    • Rappel : vous devez réduire de cinq octets la taille compatible pour les en-têtes.
    • Par exemple : arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Nouveau motif pour lequel une application peut être placée dans le bucket de mise en veille limitée

Android 14 introduit une nouvelle raison pour laquelle une application peut être placée dans le bucket de veille restreint. Les tâches de l'application déclenchent plusieurs fois des erreurs ANR en raison des délais d'inactivité des méthodes onStartJob, onStopJob ou onBind. (Pour en savoir plus sur les modifications apportées à onStartJob et onStopJob, consultez JobScheduler renforce le comportement des rappels et des réseaux.)

Pour savoir si l'application est entrée dans le bucket de veille restreint, 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 assurer une plus grande cohérence entre les appareils, Android 14 ajoute un nouveau test CTS pour la nouvelle limite mlock() sur les appareils compatibles.

Le système applique l'utilisation des ressources des applications mises en cache

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

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

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

Expérience utilisateur

Modifications apportées à la façon dont les utilisateurs gèrent les notifications qu'ils ne peuvent pas ignorer

If your app shows non-dismissable foreground notifications to users, Android 14 has changed the behavior to allow users to dismiss such notifications.

This change applies to apps that prevent users from dismissing foreground notifications by setting Notification.FLAG_ONGOING_EVENT through Notification.Builder#setOngoing(true) or NotificationCompat.Builder#setOngoing(true). The behavior of FLAG_ONGOING_EVENT has changed to make such notifications actually dismissable by the user.

These kinds of notifications are still non-dismissable in the following conditions:

  • When the phone is locked
  • If the user selects a Clear all notification action (which helps with accidental dismissals)

Also, this new behavior doesn't apply to notifications in the following use cases:

  • CallStyle notifications
  • Device policy controller (DPC) and supporting packages for enterprise
  • Media notifications
  • The default Search Selector package

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 %

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

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

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