동작 변경사항: 모든 앱

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

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

핵심 기능

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

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

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

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

On Android 14, the system can place context-registered broadcasts in a queue while the app is in the cached state. This is similar to the queuing behavior that Android 12 (API level 31) introduced for async binder transactions. Manifest-declared broadcasts aren't queued, and apps are removed from the cached state for broadcast delivery.

When the app leaves the cached state, such as returning to the foreground, the system delivers any queued broadcasts. Multiple instances of certain broadcasts might be merged into one broadcast. Depending on other factors, such as system health, apps might be removed from the cached state, and any previously queued broadcasts are delivered.

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

Android 14부터 앱이 killBackgroundProcesses()를 호출하면 API가 자체 앱의 백그라운드 프로세스만 종료할 수 있습니다.

다른 앱의 패키지 이름을 전달하면 이 메서드는 해당 앱의 백그라운드 프로세스에 영향을 미치지 않으며 Logcat에 다음 메시지가 표시됩니다.

Invalid packageName: com.example.anotherapp

앱은 killBackgroundProcesses() API를 사용하거나 이전 OS 버전에서도 다른 앱의 프로세스 수명 주기에 영향을 주려고 해서는 안 됩니다. Android는 캐시된 앱이 백그라운드에서 유지되고 시스템에 메모리가 필요할 때 자동으로 이를 종료하도록 설계되었습니다. 앱이 불필요하게 다른 앱을 종료하면 나중에 이러한 앱을 완전히 다시 시작해야 하므로 시스템 성능이 저하되고 배터리 소모가 늘어날 수 있습니다. 이로 인해 기존의 캐시된 앱을 재개하는 것보다 훨씬 많은 리소스가 소비됩니다.

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

Starting from Android 14, the Android Bluetooth stack more strictly adheres to Version 5.2 of the Bluetooth Core Specification and requests the BLE ATT MTU to 517 bytes when the first GATT client requests an MTU using the BluetoothGatt#requestMtu(int) API, and disregards all subsequent MTU requests on that ACL connection.

To address this change and make your app more robust, consider the following options:

  • Your peripheral device should respond to the Android device's MTU request with a reasonable value that can be accommodated by the peripheral. The final negotiated value will be a minimum of the Android requested value and the remote provided value (for example, min(517, remoteMtu))
    • Implementing this fix could require a firmware update for peripheral
  • Alternatively, limit your GATT characteristic writes based on the minimum between the known supported value of your peripheral and the received MTU change
    • A reminder that you should reduce 5 bytes from the supported size for the headers
    • For example: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

앱이 제한됨 대기 버킷에 배치될 수 있는 새로운 이유

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이 64KB로 제한됨

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

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

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

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

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

사용자 환경

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

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

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

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

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

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

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

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

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

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

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

접근성

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

Android 14부터 시스템은 글꼴 크기를 최대 200%까지 지원하므로 사용자에게 추가 접근성 옵션을 제공할 수 있습니다.

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

보안

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

Android 14부터 targetSdkVersion이 23 미만인 앱은 설치할 수 없습니다. 앱이 이러한 최소 대상 API 수준 요구사항을 충족하게 되면 사용자의 보안 및 개인 정보 보호 기능이 개선됩니다.

멀웨어는 최신 Android 버전에 도입된 보안 및 개인 정보 보호 기능을 우회하기 위해 이전 API 수준을 타겟팅하는 경우가 많습니다. 예를 들어 일부 멀웨어 앱은 targetSdkVersion 22를 사용하여 2015년 Android 6.0 Marshmallow(API 수준 23)에서 도입된 런타임 권한 모델이 적용되지 않도록 합니다. 이번 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에서 패키지 공개 상태를 필터링하는 방법을 자세히 알아보세요.