Android 14 플랫폼에는 앱에 영향을 줄 수 있는 동작 변경사항이 있습니다. targetSdkVersion과 관계없이 Android 14에서 실행되는 모든 앱에 적용되는 동작 변경사항은 다음과 같습니다. 이러한 변경사항을 적절히 지원해야 하는 경우 앱을 테스트한 후 필요에 따라 수정해야 합니다.
또한 Android 14를 타겟팅하는 앱에만 영향을 주는 동작 변경사항 목록을 검토해야 합니다.
핵심 기능
정확한 알람 예약은 기본적으로 거부됨
Exact alarms are meant for user-intentioned notifications, or for actions that
need to happen at a precise time. Starting in Android 14, the
SCHEDULE_EXACT_ALARM
permission is no longer being pre-granted to most newly installed apps
targeting Android 13 and higher—the permission is denied by default.
Learn more about the changes to the permission for scheduling exact alarms.
앱이 캐시되는 동안 컨텍스트 등록 브로드캐스트가 대기열에 추가됨
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 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로 제한됨
In Android 14 (API level 34) and higher, the platform reduces the maximum memory
that can be locked using mlock() to 64 KB per process. In
previous versions, the limit was 64 MB per process. This restriction
promotes better memory management across apps and the system. To provide more
consistency across devices, Android 14 adds a new CTS test for the
new mlock() limit on compatible devices.
시스템에서 캐시된 앱 리소스 사용량 적용
기본적으로 앱의 프로세스가 백그라운드로 이동되고 다른 앱 프로세스 구성요소가 실행되고 있지 않을 때 앱 프로세스는 캐시된 상태에 있습니다. 이러한 앱 프로세스는 시스템 메모리 압력으로 인해 종료될 수 있습니다. 이 상태에서는 onStop() 메서드를 호출하고 반환한 후에 Activity 인스턴스가 실행하는 모든 작업은 신뢰할 수 없으며 권장되지 않습니다.
Android 14에서는 이러한 설계에 일관성과 시행을 도입합니다. 앱 프로세스가 캐시된 상태로 전환된 직후 백그라운드 작업은 프로세스 구성요소가 수명 주기의 활성 상태로 다시 전환될 때까지 허용되지 않습니다.
서비스, JobScheduler, Jetpack WorkManager와 같이 일반적인 프레임워크 지원 수명 주기 API를 사용하는 앱은 이러한 변경사항의 영향을 받지 않습니다
사용자 환경
사용자가 닫을 수 없는 알림을 경험하는 방식 변경
If your app shows non-dismissable foreground notifications to users, Android 14 has changed the behavior to allow users to dismiss such notifications.
This change applies to apps that prevent users from dismissing foreground
notifications by setting Notification.FLAG_ONGOING_EVENT through
Notification.Builder#setOngoing(true) or
NotificationCompat.Builder#setOngoing(true). The behavior of
FLAG_ONGOING_EVENT has changed to make such notifications actually
dismissable by the user.
These kinds of notifications are still non-dismissable in the following conditions:
- When the phone is locked
- If the user selects a Clear all notification action (which helps with accidental dismissals)
Also, this new behavior doesn't apply to notifications in the following use cases:
CallStylenotifications- Device policy controller (DPC) and supporting packages for enterprise
- Media notifications
- The default Search Selector package
데이터 보안 정보가 더 잘 보임
사용자 개인 정보 보호를 강화하기 위해 Android 14에서는 개발자가 Play Console 양식에서 선언한 정보를 시스템에서 표시하는 위치 수를 늘립니다. 현재 사용자는 Google Play의 앱 등록정보에 있는 데이터 보안 섹션에서 이 정보를 볼 수 있습니다.
앱의 위치 데이터 공유 정책을 검토하고 잠시 시간을 내어 적용되는 경우 앱의 Google Play 데이터 보안 섹션을 업데이트하시기 바랍니다.
자세한 내용은 Android 14에서 데이터 보안 정보가 더 잘 표시되게 하는 방법에 관한 가이드를 참고하세요.
접근성
비선형 글꼴 크기 200%로 조정
Starting in Android 14, the system supports font scaling up to 200%, providing users with additional accessibility options.
If you already use scaled pixels (sp) units to define text sizing, then this change probably won't have a high impact on your app. However, you should perform UI testing with the maximum font size enabled (200%) to ensure that your app can accommodate larger font sizes without impacting usability.
보안
설치 가능한 최소 대상 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에서 패키지 공개 상태를 필터링하는 방법을 자세히 알아보세요.