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é

En Android 14, el sistema puede Coloca transmisiones registradas en el contexto en una fila mientras la app está en el estado almacenado en caché. Este comportamiento es similar al de la fila que presentó Android 12 (nivel de API 31) para las transacciones de Binder asíncronas. Las transmisiones declaradas en el manifiesto no están en fila, y las apps se quitan del estado almacenado en caché para la entrega de transmisiones.

Cuando la app sale del estado almacenado en caché, por ejemplo, regresa al primer plano, el sistema entrega cualquier transmisión en fila. Se pueden combinar varias instancias de ciertas transmisiones en una sola. Según otros factores, como el sistema de la aplicación, es posible que se quiten las apps del estado almacenado en caché y que se haya de transmisión.

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 Bluetooth de Android cumple de manera más estricta con la versión 5.2 de la especificación Bluetooth Core y solicita que la MTU de BLE ATT sea de 517 bytes cuando el primer cliente GATT solicita una MTU usando la API de BluetoothGatt#requestMtu(int) e ignora todas las solicitudes de MTU posteriores en esa conexión de LCA.

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

  • Tu 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 final negociado será un valor mínimo del valor solicitado por Android y el valor proporcionado de forma remota (por ejemplo, min(517, remoteMtu))
    • Implementar esta solución podría requerir una actualización del firmware del dispositivo periférico.
  • Como alternativa, limita las operaciones de escritura de características GATT según el mínimo entre el valor compatible conocido de tu periférico y el cambio de MTU recibido.
    • Un recordatorio de 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 intervalo en espera restringido

En Android 14, se introduce un nuevo motivo por el que una app se puede colocar en el intervalo de espera restringido. Los trabajos de la app activan errores de ANR varias veces debido a tiempos de espera de los métodos onStartJob, onStopJob o onBind. (Consulta JobScheduler refuerza la devolución de llamada y el comportamiento de la red para los cambios en onStartJob y onStopJob).

Para realizar un seguimiento de si la app ingresó o no al intervalo en modo de espera restringido, te recomendamos que realices el registro con la API UsageStatsManager.getAppStandbyBucket() cuando se ejecute el trabajo o con UsageStatsManager.queryEventsForSelf() cuando se inicie la app.

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 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 proporcionar más coherencia en todos los dispositivos, Android 14 agrega una nueva prueba del CTS para el nuevo límite de mlock() en los dispositivos compatibles.

El sistema aplica el uso de recursos de apps almacenados en caché

De forma predeterminada, el proceso de una app se encuentra en estado almacenado caché cuando pasa a segundo plano, y no se ejecutan otros componentes del proceso. Este proceso de app está sujeto a la finalización por la presión de la memoria del sistema. Cualquier tarea que realicen las instancias Activity después de que se haya llamado y mostrado el método onStop(), mientras esté en este estado, no es confiable ni se recomienda.

Android 14 introduce coherencia y aplicación forzosa a este diseño. Poco después de que un proceso de la app entra en un estado almacenado en caché, no se permite la tarea en segundo plano hasta que un componente del proceso vuelva a entrar en estado activo del ciclo de vida.

Las apps que usan APIs típicas de ciclo de vida compatibles con el framework (como servicios, JobScheduler y WorkManager de Jetpack) no deberían verse afectados por estos cambios.

Experiencia del usuario

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

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

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.