前景服務逾時

如果應用程式指定 Android 15 以上版本,系統會限制特定前景服務在應用程式於背景執行時的執行時間。目前這項限制僅適用於 dataSyncmediaProcessing 前景服務類型的前景服務。shortService前景服務類型的限制較嚴格,相關說明請參閱該服務類型的文件。

逾時行為

系統允許 dataSyncmediaProcessing 前景服務在 24 小時內執行最多 6 小時,之後系統會呼叫執行中服務的 Service.onTimeout(int, int) 方法 (Android 15 中導入)。(Android 15 新增了 mediaProcessing 前景服務類型)。系統會分別追蹤 dataSyncmediaProcessing 服務的六小時時間限制。舉例來說,如果 dataSync 服務只執行了一小時,應用程式就只剩下五小時可供 dataSync 前景服務使用,但 mediaProcessing 服務仍有完整的六小時可用。

前景服務達到六小時限制時,服務有幾秒時間可呼叫 Service.stopSelf()。系統呼叫 Service.onTimeout() 時,服務就不再視為前景服務。如果服務未呼叫 Service.stopSelf(),系統會擲回內部例外狀況。例外狀況會記錄在 Logcat 中,並顯示下列訊息:

Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type [service type] did not stop within its timeout: [component name]"

如要避免這項行為變更造成問題,請採取下列一或多項做法:

  1. 讓服務實作新的 Service.onTimeout(int, int) 方法。應用程式收到回呼時,請務必在幾秒內呼叫 stopSelf()。(如果沒有立即停止應用程式,系統會產生失敗訊息)。
  2. 請確保應用程式的 dataSyncmediaProcessing 服務在任何 24 小時內,總執行時間不超過 6 小時 (除非使用者與應用程式互動,重設計時器)。
  3. 只有在使用者直接互動時,才啟動 dataSyncmediaProcessing 前景服務;由於服務啟動時應用程式處於前景,因此應用程式進入背景後,服務仍有完整的六小時。
  4. 請改用 其他 API (例如 WorkManager),不要使用這些前景服務。具體來說,請考慮使用其他 API,而非 dataSync 前景服務。

如果應用程式的 dataSync 前景服務在過去 24 小時內已執行 6 小時,您就無法啟動其他 dataSync 前景服務,除非使用者已將應用程式帶到前景 (這會重設計時器)。如果您嘗試啟動其他 dataSync 前景服務,系統會擲回 ForegroundServiceStartNotAllowedException,並顯示類似「Time limit already exhausted for foreground service type dataSync」(dataSync 前景服務類型已達時間限制) 的錯誤訊息。

測試

如要測試應用程式的行為,即使應用程式並未以 Android 15 為目標,您也可以啟用資料同步逾時 (只要應用程式在 Android 15 裝置上執行即可)。如要啟用逾時,請執行下列 adb 指令:

adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name

您也可以調整逾時時間,方便測試應用程式在達到限制時的行為。如要為前台服務設定新的逾時時間,請執行下列 adb 指令:dataSync

adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds

如要為 mediaProcessing 前景服務設定新的逾時期限,請執行下列指令:

adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds