如果應用程式指定 Android 15 以上版本,系統會限制特定前景服務在應用程式於背景執行時的執行時間。目前這項限制僅適用於 dataSync
和 mediaProcessing
前景服務類型的前景服務。shortService
前景服務類型的限制較嚴格,相關說明請參閱該服務類型的文件。
逾時行為
系統允許 dataSync
和 mediaProcessing
前景服務在 24 小時內執行最多 6 小時,之後系統會呼叫執行中服務的 Service.onTimeout(int, int)
方法 (Android 15 中導入)。(Android 15 新增了 mediaProcessing
前景服務類型)。系統會分別追蹤 dataSync
和 mediaProcessing
服務的六小時時間限制。舉例來說,如果 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]"
如要避免這項行為變更造成問題,請採取下列一或多項做法:
- 讓服務實作新的
Service.onTimeout(int, int)
方法。應用程式收到回呼時,請務必在幾秒內呼叫stopSelf()
。(如果沒有立即停止應用程式,系統會產生失敗訊息)。 - 請確保應用程式的
dataSync
和mediaProcessing
服務在任何 24 小時內,總執行時間不超過 6 小時 (除非使用者與應用程式互動,重設計時器)。 - 只有在使用者直接互動時,才啟動
dataSync
或mediaProcessing
前景服務;由於服務啟動時應用程式處於前景,因此應用程式進入背景後,服務仍有完整的六小時。 - 請改用 其他 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