동작 변경사항: 모든 앱

Android 14 플랫폼에는 앱에 영향을 줄 수 있는 동작 변경사항이 포함되어 있습니다. targetSdkVersion과 관계없이 Android 14에서 실행되는 모든 앱에 적용되는 동작 변경사항은 다음과 같습니다. 이러한 변경사항을 적절히 지원해야 하는 경우 앱을 테스트한 후 필요에 따라 수정해야 합니다.

또한 Android 14를 타겟팅하는 앱에만 영향을 주는 동작 변경사항 목록을 검토해야 합니다.

핵심 기능

정확한 알람 예약은 기본적으로 거부됨

精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM 权限,该权限默认处于拒绝状态。

详细了解安排精确闹钟的权限变化

앱이 캐시되는 동안 컨텍스트 등록 브로드캐스트가 대기열에 추가됨

Android 14에서 시스템은 앱이 캐시된 상태에 있는 동안 컨텍스트 등록 브로드캐스트를 큐에 배치할 수 있습니다. 이는 Android 12(API 수준 31)에서 비동기 바인더 트랜잭션을 위해 도입한 대기열 추가 동작과 유사합니다. 매니페스트 선언 브로드캐스트는 대기열에 추가되지 않으며 앱은 브로드캐스트 전송을 위해 캐시된 상태에서 삭제됩니다.

앱이 캐시된 상태에서 나가면(예: 포그라운드로 돌아가는 경우) 시스템은 대기열에 추가된 브로드캐스트를 전송합니다. 특정 브로드캐스트의 여러 인스턴스가 하나의 브로드캐스트로 병합될 수 있습니다. 시스템 상태와 같은 다른 요소에 따라 앱은 캐시된 상태에서 삭제될 수 있으며 이전에 큐에 추가된 브로드캐스트는 모두 전송됩니다.

앱은 자체 백그라운드 프로세스만 종료할 수 있음

从 Android 14 开始,当您的应用调用 killBackgroundProcesses() 时,该 API 只能终止您自己应用的后台进程。

如果您传入另一个应用的软件包名称,此方法对该应用的后台进程没有影响,并且 Logcat 中会显示以下消息:

Invalid packageName: com.example.anotherapp

您的应用不应使用 killBackgroundProcesses() API,也不得以其他方式尝试影响其他应用的进程生命周期,即使在旧版操作系统上也是如此。Android 旨在让缓存应用在后台运行,并在系统需要内存时自动终止它们。如果您的应用会不必要地终止其他应用,则由于之后需要完全重启这些应用,因此可能会降低系统性能并增加耗电量,这比恢复现有缓存应用所消耗的资源要多得多。

MTU를 요청하는 첫 번째 GATT 클라이언트의 경우 MTU가 517로 설정됨

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

앱을 제한된 대기 버킷에 배치할 수 있는 새로운 이유

Android 14 引入了将应用放入“受限待机”分桶的新原因。由于 onStartJobonStopJobonBind 方法超时,应用的作业会多次触发 ANR 错误。(如需了解对 onStartJobonStopJob 的更改,请参阅 JobScheduler 增强回调和网络行为。)

如需跟踪应用是否已进入“受限待机”分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket() 进行日志记录,或者在应用启动时使用 UsageStatsManager.queryEventsForSelf() 进行日志记录。

mlock이 64KB로 제한

Android 14 (API 수준 34) 이상에서 플랫폼은 mlock()를 사용하여 잠글 수 있는 최대 메모리를 프로세스당 64KB로 줄입니다. 이전 버전에서는 프로세스당 64MB로 제한되었습니다. 이러한 제한사항으로 인해 앱과 시스템 전반에서 더 나은 메모리 관리가 가능합니다. 기기 간에 더 높은 일관성을 제공하기 위해 Android 14에서는 호환되는 기기의 새로운 mlock() 제한에 관한 새로운 CTS 테스트를 추가합니다.

시스템에서 캐시된 앱 리소스 사용 적용

기본적으로 앱의 프로세스가 백그라운드로 이동되고 다른 앱 프로세스 구성요소가 실행되고 있지 않을 때 앱 프로세스는 캐시된 상태에 있습니다. 이러한 앱 프로세스는 시스템 메모리 압력으로 인해 종료될 수 있습니다. 이 상태에서는 onStop() 메서드를 호출하고 반환한 후에 Activity 인스턴스가 실행하는 모든 작업은 신뢰할 수 없으며 권장되지 않습니다.

Android 14에서는 이러한 설계에 일관성과 시행을 도입합니다. 앱 프로세스가 캐시된 상태로 전환된 직후 백그라운드 작업은 프로세스 구성요소가 수명 주기의 활성 상태로 다시 전환될 때까지 허용되지 않습니다.

서비스, JobScheduler, Jetpack WorkManager와 같이 일반적인 프레임워크 지원 수명 주기 API를 사용하는 앱은 이러한 변경사항의 영향을 받지 않습니다

사용자 환경

사용자가 닫을 수 없는 알림을 경험하는 방식 변경

如果您的应用向用户显示不可关闭的前台通知,请注意:Android 14 已更改此行为,允许用户关闭此类通知。

这项变更适用于通过 Notification.Builder#setOngoing(true)NotificationCompat.Builder#setOngoing(true) 设置 Notification.FLAG_ONGOING_EVENT 来阻止用户关闭前台通知的应用。FLAG_ONGOING_EVENT 的行为已发生变化,使用户实际上能够关闭此类通知。

在以下情况下,此类通知仍不可关闭:

  • 当手机处于锁定状态时
  • 如果用户选择全部清除通知操作(有助于防止意外关闭)

此外,这种新行为不适用于以下用例中的通知:

  • CallStyle 通知
  • 企业设备政策控制器 (DPC) 和支持软件包
  • 媒体通知
  • 默认的搜索选择器软件包

데이터 보안 정보가 더 잘 보임

为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。

我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。

如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。

접근성

비선형 글꼴 크기 200%로 조정

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

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

보안

설치 가능한 최소 대상 API 수준

从 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

미디어 소유자 패키지 이름이 수정될 수 있음

媒体库支持查询 OWNER_PACKAGE_NAME 列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:

  • 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
  • 查询媒体库的应用会请求 QUERY_ALL_PACKAGES 权限。

详细了解 Android 如何出于隐私保护目的而过滤软件包可见性