동작 변경사항: 모든 앱

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

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

핵심 기능

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

정확한 알람은 사용자가 의도한 알림이나 정확한 시간에 실행해야 하는 작업을 위한 것입니다. Android 14부터 SCHEDULE_EXACT_ALARM 권한은 Android 13 이상을 타겟팅하는 새로 설치된 대부분의 앱에 더 이상 사전 부여되지 않습니다. 즉, 권한이 기본적으로 거부됩니다.

정확한 알람을 예약하는 권한의 변경사항에 관해 자세히 알아보세요.

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

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에서는 앱이 제한된 대기 버킷에 배치될 수 있는 새로운 이유를 도입합니다. 앱의 작업이 onStartJob, onStopJob 또는 onBind 메서드 시간 초과로 인해 ANR 오류를 여러 번 트리거합니다. onStartJobonStopJob의 변경사항은 JobScheduler가 콜백 및 네트워크 동작을 강화합니다를 참고하세요.

앱이 제한된 대기 버킷에 진입했는지 추적하려면 작업 실행 시 API UsageStatsManager.getAppStandbyBucket() 또는 앱 시작 시 UsageStatsManager.queryEventsForSelf()를 사용하여 로깅하는 것이 좋습니다.

mlock이 64KB로 제한됨

在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock() 锁定的最大内存量减少到每个进程 64 KB。在之前的版本中,每个进程的上限为 64 MB。此限制有助于更好地管理应用和系统的内存。为了在各种设备上提供更一致的体验,Android 14 针对兼容设备上的新 mlock() 限制添加了一项新的 CTS 测试

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

从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity 实例在调用并返回 onStop() 方法后执行的任何工作均不可靠,强烈建议不要这样做。

Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。

使用框架支持的典型生命周期 API(例如服务JobSchedulerJetpack WorkManager)的应用应该不受这些变化的影响。

사용자 환경

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

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

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

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

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

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

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

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

사용자 개인 정보 보호를 강화하기 위해 Android 14에서는 개발자가 Play Console 양식에서 선언한 정보를 시스템에서 표시하는 위치 수를 늘립니다. 현재 사용자는 Google Play의 앱 등록정보에 있는 데이터 보안 섹션에서 이 정보를 볼 수 있습니다.

앱의 위치 데이터 공유 정책을 검토하고 잠시 시간을 내어 적용되는 경우 앱의 Google Play 데이터 보안 섹션을 업데이트하시기 바랍니다.

자세한 내용은 Android 14에서 데이터 보안 정보가 더 잘 표시되게 하는 방법에 관한 가이드를 참고하세요.

접근성

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

Android 14부터 시스템은 글꼴 크기를 최대 200%까지 지원합니다. 이를 통해 저시력 사용자에게 웹 콘텐츠 접근성 가이드라인(WCAG)에 맞는 추가 접근성 옵션을 제공할 수 있습니다.

이미 조정된 픽셀(sp) 단위를 사용하여 텍스트 크기를 정의한다면 이 변경사항은 앱에 큰 영향을 미치지 않을 것입니다. 그러나 최대 글꼴 크기(200%)를 사용 설정한 상태에서 UI 테스트를 실행하여 앱이 사용성에 영향을 미치지 않으면서 더 큰 글꼴 크기를 수용할 수 있는지 확인해야 합니다.

보안

설치 가능한 최소 대상 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 如何出于隐私保护目的而过滤软件包可见性