동작 변경사항: 모든 앱

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

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

핵심 기능

Android 16에는 Android 시스템의 다양한 핵심 기능을 수정하거나 확장하는 다음과 같은 변경사항이 포함되어 있습니다.

JobScheduler 할당량 최적화

Android 16부터 다음 요소를 기반으로 일반 및 신속한 작업 실행 런타임 할당량이 조정됩니다.

  • 애플리케이션이 있는 앱 대기 버킷: Android 16에서는 활성 대기 버킷이 넉넉한 런타임 할당량으로 시행되기 시작합니다.
  • 앱이 최상위 상태에 있는 동안 작업 실행이 시작되는 경우: Android 16에서는 앱이 사용자에게 표시되는 동안 시작된 작업이 앱이 표시되지 않게 된 후에도 계속되면 작업 런타임 할당량을 준수합니다.
  • 포그라운드 서비스를 실행하는 동안 작업이 실행되는 경우: Android 16에서는 포그라운드 서비스와 동시에 실행되는 작업이 작업 런타임 할당량을 준수합니다. 사용자가 시작한 데이터 전송에 작업을 활용하는 경우 대신 사용자가 시작한 데이터 전송 작업을 사용하는 것이 좋습니다.

이 변경사항은 WorkManager, JobScheduler, DownloadManager를 사용하여 예약된 작업에 영향을 미칩니다. 작업이 중지된 이유를 디버그하려면 WorkInfo.getStopReason()를 호출하여 작업이 중지된 이유를 로깅하는 것이 좋습니다 (JobScheduler 작업의 경우 JobParameters.getStopReason() 호출).

배터리 최적화 권장사항에 관한 자세한 내용은 작업 예약 API의 배터리 사용량 최적화 가이드를 참고하세요.

또한 Android 16에서 도입된 새로운 JobScheduler#getPendingJobReasonsHistory API를 활용하여 작업이 실행되지 않은 이유를 파악하는 것이 좋습니다.

테스트

앱의 동작을 테스트하려면 앱이 Android 16 기기에서 실행되는 한 특정 작업 할당량 최적화 재정의를 사용 설정할 수 있습니다.

'최상위 상태가 작업 런타임 할당량을 준수합니다'의 시행을 사용 중지하려면 다음 adb 명령어를 실행합니다.

adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_TOP_STARTED_JOBS APP_PACKAGE_NAME

'포그라운드 서비스와 동시에 실행되는 작업은 작업 런타임 할당량을 준수합니다'의 시행을 사용 중지하려면 다음 adb 명령어를 실행합니다.

adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_FGS_JOBS APP_PACKAGE_NAME

특정 앱 대기 버킷 동작을 테스트하려면 다음 adb 명령어를 사용하여 앱의 앱 대기 버킷을 설정하면 됩니다.

adb shell am set-standby-bucket APP_PACKAGE_NAME active|working_set|frequent|rare|restricted

앱이 있는 앱 대기 버킷을 알아보려면 다음 adb 명령어를 사용하여 앱의 앱 대기 버킷을 가져오면 됩니다.

adb shell am get-standby-bucket APP_PACKAGE_NAME

JobInfo#setImportantWhileForeground를 완전히 지원 중단했습니다.

JobInfo.Builder#setImportantWhileForeground(boolean) 메서드는 예약 앱이 포그라운드에 있거나 일시적으로 백그라운드 제한사항에서 제외된 경우 작업의 중요도를 나타냅니다.

이 메서드는 Android 12 (API 수준 31)부터 지원 중단되었습니다. Android 16부터는 더 이상 효과적으로 작동하지 않으며 이 메서드를 호출해도 무시됩니다.

이 기능 삭제는 JobInfo#isImportantWhileForeground()에도 적용됩니다. Android 16부터 메서드가 호출되면 메서드는 false를 반환합니다.

사용자 환경 및 시스템 UI

Android 16에는 더 일관되고 직관적인 사용자 환경을 제공하기 위한 다음과 같은 변경사항이 포함되어 있습니다.

방해가 되는 접근성 안내 지원 중단

Android 16에서는 announceForAccessibility 사용 또는 TYPE_ANNOUNCEMENT 접근성 이벤트 전송으로 특징되는 접근성 공지사항을 지원 중단합니다. 이로 인해 TalkBack 및 Android의 스크린 리더 사용자에게 일관되지 않은 사용자 환경이 발생할 수 있으며, 대안은 다양한 Android의 보조 기술에서 더 광범위한 사용자 요구사항을 충족합니다.

대안의 예:

지원 중단된 announceForAccessibility API의 참조 문서에는 추천 대안에 관한 자세한 내용이 포함되어 있습니다.