Платформа Android 16 включает изменения в поведении, которые могут повлиять на ваше приложение. Следующие изменения поведения применяются ко всем приложениям , работающим на Android 16, независимо от targetSdkVersion
. Вам следует протестировать свое приложение, а затем при необходимости изменить его для поддержки этих изменений, где это применимо.
Обязательно ознакомьтесь также со списком изменений поведения, которые влияют только на приложения, предназначенные для Android 16 .
Основная функциональность
Android 16 включает следующие изменения, которые изменяют или расширяют различные основные возможности системы Android.
Оптимизация квот JobScheduler
Начиная с Android 16, мы корректируем квоту времени выполнения обычных и ускоренных заданий на основе следующих факторов:
- В каком резервном сегменте приложения находится приложение : в Android 16 активные резервные сегменты начнут обеспечиваться щедрой квотой времени выполнения.
- Если задание начинает выполнение, когда приложение находится в верхнем состоянии : в Android 16 задания запускаются, пока приложение видно пользователю, и продолжаются после того, как приложение становится невидимым, будут соответствовать квоте времени выполнения задания.
- Если задание выполняется во время работы службы переднего плана : в Android 16 задания, которые выполняются одновременно со службой переднего плана, будут соответствовать квоте времени выполнения задания. Если вы используете задания для передачи данных, инициируемой пользователем, рассмотрите возможность использования вместо этого заданий передачи данных, инициируемых пользователем .
Это изменение влияет на задачи, запланированные с помощью WorkManager, JobScheduler и DownloadManager. Чтобы выяснить, почему задание было остановлено, мы рекомендуем записать причину, по которой ваше задание было остановлено, вызвав WorkInfo.getStopReason()
(для заданий JobScheduler вызовите JobParameters.getStopReason()
).
Дополнительные сведения о рекомендациях по оптимальному использованию аккумулятора см. в руководстве по оптимизации использования аккумулятора для API планирования задач .
Мы также рекомендуем использовать новый API JobScheduler#getPendingJobReasonsHistory
представленный в Android 16, чтобы понять, почему задание не выполнено.
Тестирование
Чтобы проверить поведение вашего приложения, вы можете включить переопределение определенных оптимизаций квоты заданий, пока приложение работает на устройстве 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
。
Пользовательский опыт и системный интерфейс
Android 16 включает следующие изменения, призванные создать более последовательный и интуитивно понятный пользовательский интерфейс.
Отказ от деструктивных объявлений о доступности
Android 16 deprecates accessibility announcements, characterized by the use of
announceForAccessibility
or the dispatch of
TYPE_ANNOUNCEMENT
accessibility events. These can create
inconsistent user experiences for users of TalkBack and Android's screen reader,
and alternatives better serve a broader range of user needs across a variety of
Android's assistive technologies.
Examples of alternatives:
- For significant UI changes like window changes, use
Activity.setTitle(CharSequence)
andsetAccessibilityPaneTitle(java.lang.CharSequence)
. In Compose, useModifier.semantics { paneTitle = "paneTitle" }
- To inform the user of changes to critical UI, use
setAccessibilityLiveRegion(int)
. In Compose, useModifier.semantics { liveRegion = LiveRegionMode.[Polite|Assertive]}
. These should be used sparingly as they may generate announcements every time a View is updated. - To notify users about errors, send an
AccessibilityEvent
of typeAccessibilityEvent#CONTENT_CHANGE_TYPE_ERROR
and setAccessibilityNodeInfo#setError(CharSequence)
, or useTextView#setError(CharSequence)
.
The reference documentation for the deprecated
announceForAccessibility
API includes more details about
suggested alternatives.