동작 변경사항: 모든 앱

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.

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

Starting in Android 14, when your app calls killBackgroundProcesses(), the API can kill only the background processes of your own app.

If you pass in the package name of another app, this method has no effect on that app's background processes, and the following message appears in Logcat:

Invalid packageName: com.example.anotherapp

Your app shouldn't use the killBackgroundProcesses() API or otherwise attempt to influence the process lifecycle of other apps, even on older OS versions. Android is designed to keep cached apps in the background and kill them automatically when the system needs memory. If your app kills other apps unnecessarily, it can reduce system performance and increase battery consumption by requiring full restarts of those apps later, which takes significantly more resources than resuming an existing cached app.

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

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

By design, an app's process is in a cached state when it's moved to the background and no other app process components are running. Such an app process is subject to being killed due to system memory pressure. Any work that Activity instances perform after the onStop() method has been called and returned, while in this state, is unreliable and strongly discouraged.

Android 14 introduces consistency and enforcement to this design. Shortly after an app process enters a cached state, background work is disallowed, until a process component re-enters an active state of the lifecycle.

Apps that use typical framework-supported lifecycle APIs – such as services, JobScheduler, and Jetpack WorkManager – shouldn't be impacted by these changes.

사용자 환경

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

앱에서 사용자에게 닫을 수 없는 포그라운드 알림을 표시하는 경우 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 수준 요구사항을 충족하게 되면 사용자의 보안 및 개인 정보 보호 기능이 개선됩니다.

멀웨어는 최신 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

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

The media store supports queries for the OWNER_PACKAGE_NAME column, which indicates the app that stored a particular media file. Starting in Android 14, this value is redacted unless at least one of the following conditions is true:

  • The app that stored the media file has a package name that is always visible to other apps.
  • The app that queries the media store requests the QUERY_ALL_PACKAGES permission.

Learn more about how Android filters package visibility for privacy purposes.