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.
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.
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
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
为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。
我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。
如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。
Accessibilité
Mise à l'échelle non linéaire de la police à 200 %
Starting in Android 14, the system supports font scaling up to 200%, providing users with additional accessibility options.
If you already use scaled pixels (sp) units to define text sizing, then this change probably won't have a high impact on your app. However, you should perform UI testing with the maximum font size enabled (200%) to ensure that your app can accommodate larger font sizes without impacting usability.
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
The media store supports queries for the OWNER_PACKAGE_NAME column, which
indicates the app that stored a particular media file. Starting in Android
14, this value is redacted unless at least one of the following conditions is
true:
- The app that stored the media file has a package name that is always visible to other apps.
The app that queries the media store requests the
QUERY_ALL_PACKAGESpermission.
Learn more about how Android filters package visibility for privacy purposes.