La plataforma de Android 14 incluye cambios de comportamiento que podrían afectar a tu app.
Los siguientes cambios de comportamiento 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
Exact alarms are meant for user-intentioned notifications, or for actions that
need to happen at a precise time. Starting in Android 14, the
SCHEDULE_EXACT_ALARM
permission is no longer being pre-granted to most newly installed apps
targeting Android 13 and higher—the permission is denied by default.
Learn more about the changes to the permission for scheduling exact alarms.
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 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 intervalo en espera restringido
Android 14 introduces a new reason an app can be placed into the restricted standby bucket.
The app's jobs trigger ANR errors multiple times due to onStartJob
,
onStopJob
, or onBind
method timeouts.
(See JobScheduler reinforces callback and network behavior for changes
to onStartJob
and onStopJob
.)
To track whether or not the app has entered the restricted standby bucket,
we recommend logging with the API UsageStatsManager.getAppStandbyBucket()
on job execution or UsageStatsManager.queryEventsForSelf()
on app startup.
mlock se limita 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 de manera forzosa el uso de recursos de la app almacenada en caché
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
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
To enhance user privacy, Android 14 increases the number of places where the system shows the information you have declared in the Play Console form. Currently, users can view this information in the Data safety section on your app's listing in Google Play.
We encourage you to review your app's location data sharing policies and take a moment to make any applicable updates to your app's Google Play Data safety section.
Learn more in the guide about how data safety information is more visible on 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
媒体库支持查询 OWNER_PACKAGE_NAME
列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:
- 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
查询媒体库的应用会请求
QUERY_ALL_PACKAGES
权限。
详细了解 Android 如何出于隐私保护目的而过滤软件包可见性。