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
精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM
权限,该权限默认处于拒绝状态。
详细了解安排精确闹钟的权限变化。
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 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
在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock()
锁定的最大内存量减少到每个进程 64 KB。在之前的版本中,每个进程的上限为 64 MB。此限制有助于更好地管理应用和系统的内存。为了在各种设备上提供更一致的体验,Android 14 针对兼容设备上的新 mlock()
限制添加了一项新的 CTS 测试。
El sistema aplica el uso de recursos de apps almacenados 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
如果您的应用向用户显示不可关闭的前台通知,请注意: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
为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。
我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。
如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。
Accesibilidad
Escalamiento de fuente no lineal al 200%
从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。
如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。
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
媒体库支持查询 OWNER_PACKAGE_NAME
列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:
- 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
查询媒体库的应用会请求
QUERY_ALL_PACKAGES
权限。
详细了解 Android 如何出于隐私保护目的而过滤软件包可见性。