Cambios de comportamiento: todas las apps

La plataforma de Android 14 incluye cambios de comportamiento que podrían afectar a tu app. Los siguientes cambios se aplican a todas las apps cuando se ejecutan en Android 14, independientemente de targetSdkVersion. Debes probar tu app y, luego, modificarla según corresponda para admitir estos cambios.

Asegúrate también de consultar la lista de cambios de comportamiento que solo afectan a las apps orientadas a Android 14.

Funcionalidad principal

El permiso para programar alarmas exactas se rechaza de forma predeterminada

Las alarmas exactas están diseñadas para notificaciones destinadas a usuarios o para acciones que deben realizarse en un momento preciso. A partir de Android 14, el permiso SCHEDULE_EXACT_ALARM ya no se otorga, de forma previa, a la mayoría de las apps instaladas más recientemente que se orienten a Android 13 y versiones posteriores; el permiso se rechaza de forma predeterminada.

Obtén más información sobre los cambios en el permiso para programar alarmas exactas.

Las transmisiones registradas en el contexto se ponen en cola mientras las apps se almacenan en caché

在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。

当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。

Las apps solo pueden finalizar sus propios procesos en segundo plano

A partir de Android 14, cuando tu app llame a killBackgroundProcesses(), la API solo puede finalizar los procesos en segundo plano de tu propia app.

Si pasas el nombre del paquete de otra app, este método no tiene efecto en los procesos en segundo plano de esa app, y aparece el siguiente mensaje en Logcat:

Invalid packageName: com.example.anotherapp

Tu app no debe usar la API de killBackgroundProcesses() ni intentar influir, de otra manera, en el ciclo de vida del proceso de otras apps, incluso en versiones anteriores del SO. Android se diseñó para mantener las apps almacenadas en caché en segundo plano y eliminarlas automáticamente cuando el sistema necesite memoria. Si tu app finaliza, de forma innecesaria, otras apps, puede reducir el rendimiento del sistema y aumentar el consumo de batería, ya que se requieren reinicios completos de esas apps más adelante, lo que exige muchos más recursos que reanudar una app existente almacenada en caché.

La MTU se establece en 517 para el primer cliente GATT que solicita una MTU.

A partir de Android 14, la pila de Bluetooth de Android se adhiere de manera más estricta a la versión 5.2 de la Especificación principal de Bluetooth y solicita la MTU de ATT BLE a 517 bytes cuando el primer cliente de GATT solicita una MTU con la API de BluetoothGatt#requestMtu(int) y no tiene en cuenta todas las solicitudes de MTU posteriores en esa conexión de ACL.

Para abordar este cambio y hacer que tu app sea más sólida, considera las siguientes opciones:

  • El dispositivo periférico debe responder a la solicitud de MTU del dispositivo Android con un valor razonable que el periférico pueda admitir. El valor negociado final será un mínimo del valor solicitado por Android y el valor proporcionado de forma remota (por ejemplo, min(517, remoteMtu)).
    • La implementación de esta solución podría requerir una actualización de firmware para el periférico.
  • Como alternativa, limita las operaciones de escritura de la característica GATT según el valor mínimo entre el valor admitido conocido de tu periférico y el cambio de MTU recibido.
    • Te recordamos que debes reducir 5 bytes del tamaño admitido para los encabezados.
    • Por ejemplo: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Nuevo motivo por el que una app puede colocarse en el bucket de espera restringido

Android 14 引入了一种可将应用放入受限待机模式存储分区的新原因。由于 onStartJobonStopJobonBind 方法超时,应用的作业多次触发 ANR 错误。(如需了解对 onStartJobonStopJob 的更改,请参阅 JobScheduler 强化了回调和网络行为。)

如需跟踪应用是否已进入受限待机分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket() 进行日志记录,或在应用启动时使用 UsageStatsManager.queryEventsForSelf() 进行日志记录。

mlock limitado a 64 KB

En Android 14 (nivel de API 34) y versiones posteriores, la plataforma reduce la memoria máxima que se puede bloquear con mlock() a 64 KB por proceso. En las versiones anteriores, el límite era de 64 MB por proceso. Esta restricción promueve una mejor administración de la memoria en las apps y el sistema. Para brindar mayor coherencia entre los dispositivos, Android 14 agrega una nueva prueba de CTS para el nuevo límite de mlock() en los dispositivos compatibles.

El sistema aplica el uso de recursos de las apps almacenadas en caché

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

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

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

Experiencia del usuario

Cambios en la experiencia de los usuarios con notificaciones que no se pueden descartar

如果您的应用向用户显示不可关闭的前台通知,请注意:Android 14 已更改此行为,允许用户关闭此类通知。

这项变更适用于阻止用户关闭前台的应用 将 Notification.FLAG_ONGOING_EVENT 设置为 Notification.Builder#setOngoing(true)NotificationCompat.Builder#setOngoing(true)FLAG_ONGOING_EVENT 的行为已发生变化,使用户实际上能够关闭此类通知。

在以下情况下,此类通知仍不可关闭:

  • 当手机处于锁定状态时
  • 如果用户选择全部清除通知操作(有助于防止意外关闭)

此外,这一新行为不适用于以下用例中的通知:

  • CallStyle 条通知
  • 企业设备政策控制器 (DPC) 和支持软件包
  • 媒体通知
  • 默认的搜索选择器软件包

La información de seguridad de los datos es más visible

Para mejorar la privacidad del usuario, Android 14 aumenta la cantidad de lugares en los que el sistema muestra la información que declaraste en el formulario de Play Console. En la actualidad, los usuarios pueden ver esta información en la sección Seguridad de los datos de la ficha de tu app en Google Play.

Te recomendamos que revises las políticas de uso compartido de datos de ubicación de tu app y te tomes un momento para realizar las actualizaciones correspondientes en la sección de Seguridad de los datos de Google Play.

Obtén más información en la guía sobre cómo la información de seguridad de los datos es más visible en Android 14.

Accesibilidad

Escalamiento de fuente no lineal al 200%

A partir de Android 14, el sistema admite el escalamiento de la fuente hasta el 200%, lo que les brinda a los usuarios con visión reducida opciones de accesibilidad adicionales que se alinean con las Pautas de Accesibilidad al Contenido Web (WCAG).

Si ya usas unidades de píxeles ajustados (sp) para definir el tamaño del texto, es probable que estos cambios no produzcan un gran impacto en tu app. Sin embargo, debes realizar pruebas de IU con el tamaño de fuente máximo habilitado (200%) para asegurarte de que tu app pueda admitir tamaños de fuente más grandes sin afectar la usabilidad.

Seguridad

Nivel mínimo de API objetivo instalable

A partir de Android 14, no se pueden instalar apps con un targetSdkVersion inferior a 23. Exigir a las apps que cumplan con estos requisitos mínimos del nivel de API objetivo mejora la seguridad y la privacidad de los usuarios.

Con frecuencia, el software malicioso se orienta a niveles de APIs más antiguos para evitar las protecciones de seguridad y privacidad que se introdujeron en las versiones más recientes de Android. Por ejemplo, algunas apps de software malicioso usan targetSdkVersion de 22 para evitar que estén sujetas al modelo de permisos de tiempo de ejecución que, en 2015, introdujo Android 6.0 Marshmallow (nivel de API 23). Este cambio en Android 14 dificulta que el software malicioso evite las mejoras de seguridad y privacidad. Si intentas instalar una app que se oriente a un nivel de API inferior, se producirá un error de instalación y se mostrará el siguiente mensaje en Logcat:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7

En los dispositivos que se actualizan a Android 14, las apps que tengan un targetSdkVersion inferior a 23 permanecerán instaladas.

Si necesitas probar una app que se oriente a un nivel de API anterior, usa el siguiente comando de adb:

adb install --bypass-low-target-sdk-block FILENAME.apk

Los nombres de los paquetes de los propietarios del contenido multimedia podrían estar ocultos

La tienda de contenido multimedia admite consultas para la columna OWNER_PACKAGE_NAME, que indica la app que almacenó un archivo multimedia en particular. A partir de Android 14, este valor se oculta, a menos que se cumpla mínimo una de las siguientes condiciones:

  • La app que almacenó el archivo multimedia tiene un nombre de paquete que siempre está visible para otras apps.
  • La app que consulta la tienda de contenido multimedia solicita el permiso QUERY_ALL_PACKAGES.

Descubre cómo Android filtra la visibilidad de paquetes por motivos de privacidad.