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

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 bucket de App Standby restringido

Android 14 introduce un nuevo motivo por el que una app puede colocarse en el bucket de App Standby restringido. Las tareas de la app activan errores de ANR varias veces debido a los tiempos de espera de los métodos onStartJob, onStopJob o onBind. (Consulta JobScheduler refuerza el comportamiento de devolución de llamada y de red para conocer los cambios en onStartJob y onStopJob).

Para hacer un seguimiento de si la app ingresó o no al bucket de espera restringido, te recomendamos que accedas con la API UsageStatsManager.getAppStandbyBucket() en la ejecución de la tarea o UsageStatsManager.queryEventsForSelf() en el inicio de la app.

mlock limitado a 64 KB

In Android 14 (API level 34) and higher, the platform reduces the maximum memory that can be locked using mlock() to 64 KB per process. In previous versions, the limit was 64 MB per process. This restriction promotes better memory management across apps and the system. To provide more consistency across devices, Android 14 adds a new CTS test for the new mlock() limit on compatible devices.

El sistema aplica el uso de recursos de apps almacenados 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

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

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%

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。

Seguridad

Nivel mínimo de API objetivo instalable

Starting with Android 14, apps with a targetSdkVersion lower than 23 can't be installed. Requiring apps to meet these minimum target API level requirements improves security and privacy for users.

Malware often targets older API levels in order to bypass security and privacy protections that have been introduced in newer Android versions. For example, some malware apps use a targetSdkVersion of 22 to avoid being subjected to the runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API level 23). This Android 14 change makes it harder for malware to avoid security and privacy improvements. Attempting to install an app targeting a lower API level will result in an installation failure, with the following message appearing in Logcat:

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

On devices upgrading to Android 14, any apps with a targetSdkVersion lower than 23 will remain installed.

If you need to test an app targeting an older API level, use the following ADB command:

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 如何出于隐私保护目的而过滤软件包可见性