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를 사용하거나 이전 OS 버전에서도 다른 앱의 프로세스 수명 주기에 영향을 주려고 해서는 안 됩니다.
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 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를 사용하는 앱은 이러한 변경사항의 영향을 받지 않습니다
사용자 환경
사용자가 닫을 수 없는 알림을 처리하는 방식 변경
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:
CallStyle
notifications- 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%로 조정
Android 14부터 시스템은 글꼴 크기를 최대 200%까지 지원합니다. 이를 통해 저시력 사용자에게 웹 콘텐츠 접근성 가이드라인(WCAG)에 맞는 추가 접근성 옵션을 제공할 수 있습니다.
이미 조정된 픽셀(sp) 단위를 사용하여 텍스트 크기를 정의한다면 이 변경사항은 앱에 큰 영향을 미치지 않을 것입니다. 그러나 최대 글꼴 크기(200%)를 사용 설정한 상태에서 UI 테스트를 실행하여 앱이 사용성에 영향을 미치지 않으면서 더 큰 글꼴 크기를 수용할 수 있는지 확인해야 합니다.
보안
설치 가능한 최소 대상 API 수준
Starting with Android 14, apps with a
targetSdkVersion
lower than 23
can't be installed. Requiring apps to meet these minimum target API level
requirements improves security and privacy for users.
Malware often targets older API levels in order to bypass security and privacy
protections that have been introduced in newer Android versions. For example,
some malware apps use a targetSdkVersion
of 22 to avoid being subjected to the
runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API
level 23). This Android 14 change makes it harder for malware to avoid security
and privacy improvements.
Attempting to install an app targeting a lower API level will result in an
installation failure, with the following message appearing in Logcat:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
On devices upgrading to Android 14, any apps with a targetSdkVersion
lower
than 23 will remain installed.
If you need to test an app targeting an older API level, use the following ADB command:
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.