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.
从 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
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
Si tu app les muestra a los usuarios notificaciones que no se pueden descartar en primer plano, Android 14 cambió el comportamiento para permitir que los usuarios puedan hacerlo.
Este cambio se aplica a las apps que impiden que los usuarios descarten el primer plano.
las notificaciones estableciendo Notification.FLAG_ONGOING_EVENT
con
Notification.Builder#setOngoing(true)
o
NotificationCompat.Builder#setOngoing(true)
Se modificó el comportamiento de FLAG_ONGOING_EVENT
para que el usuario pueda descartar realmente estas notificaciones.
Estos tipos de notificaciones aún no se pueden descartar en las siguientes situaciones:
- Si el teléfono está bloqueado.
- Si el usuario selecciona una acción de notificación Borrar todo (lo que ayuda cuando se descartan por accidente).
Además, este nuevo comportamiento no se aplica a las notificaciones de la los siguientes casos de uso:
- Notificaciones de
CallStyle
- Controlador de políticas del dispositivo (DPC) y paquetes de asistencia para empresas
- Notificaciones multimedia
- El paquete del Selector de búsqueda predeterminado
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
从 Android 14 开始,targetSdkVersion
低于 23 的应用无法安装。要求应用满足这些最低目标 API 级别要求有助于提高用户的安全性和隐私性。
恶意软件通常会以较旧的 API 级别为目标平台,以绕过在较新版本 Android 中引入的安全和隐私保护机制。例如,有些恶意软件应用使用 targetSdkVersion
22,以避免受到 Android 6.0 Marshmallow(API 级别 23)在 2015 年引入的运行时权限模型的约束。这项 Android 14 变更使恶意软件更难以规避安全和隐私权方面的改进限制。尝试安装以较低 API 级别为目标平台的应用将导致安装失败,并且 Logcat 中会显示以下消息:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
在升级到 Android 14 的设备上,targetSdkVersion
低于 23 的所有应用都将继续保持安装状态。
如果您需要测试以旧版 API 级别为目标平台的应用,请使用以下 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.