Jika aplikasi menargetkan Android 15 atau yang lebih tinggi, sistem akan menerapkan batasan pada durasi layanan latar depan tertentu diizinkan berjalan saat aplikasi Anda berada di latar belakang. Saat ini, batasan ini hanya berlaku untuk
dataSync dan
mediaProcessing jenis layanan latar depan latar depan
layanan. Ada batasan yang lebih ketat pada jenis layanan latar depan shortService yang dibahas dalam dokumentasi jenis layanan tersebut.
Perilaku waktu tunggu
Sistem mengizinkan layanan latar depan dataSync dan mediaProcessing berjalan
selama total 6 jam dalam periode 24 jam, setelah itu sistem akan memanggil metode Service.onTimeout(int, int) layanan yang
berjalan (diperkenalkan di Android 15). (Jenis layanan latar depan mediaProcessing ditambahkan di Android 15.) Batas waktu enam jam dilacak secara terpisah untuk layanan dataSync dan mediaProcessing. Misalnya, jika layanan dataSync baru berjalan selama satu jam, aplikasi hanya akan memiliki waktu lima jam untuk layanan latar depan dataSync, tetapi akan memiliki waktu enam jam penuh untuk layanan mediaProcessing.
Saat layanan latar depan mencapai batas enam jam, layanan tersebut memiliki waktu beberapa
detik untuk memanggil Service.stopSelf(). Saat sistem memanggil Service.onTimeout(), layanan tidak lagi dianggap sebagai layanan latar depan.
Jika layanan tidak memanggil Service.stopSelf(), sistem akan menampilkan pengecualian internal. Pengecualian dicatat di Logcat dengan pesan berikut:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type [service type] did not stop within its timeout: [component name]"
Untuk menghindari masalah dengan perubahan perilaku ini, Anda dapat melakukan satu atau beberapa hal berikut:
- Membuat layanan Anda menerapkan metode
Service.onTimeout(int, int)baru. Saat aplikasi Anda menerima callback, pastikan untuk memanggilstopSelf()dalam beberapa detik. (Jika Anda tidak segera menghentikan aplikasi, sistem akan menghasilkan kegagalan.) - Pastikan layanan
dataSyncdanmediaProcessingaplikasi Anda tidak berjalan selama lebih dari total 6 jam dalam periode 24 jam (kecuali jika pengguna berinteraksi dengan aplikasi, yang akan mereset timer). - Hanya memulai layanan latar depan
dataSyncataumediaProcessingsebagai hasil interaksi pengguna langsung; karena aplikasi Anda berada di latar depan saat layanan dimulai, layanan Anda memiliki waktu enam jam penuh setelah aplikasi masuk ke latar belakang. - Daripada menggunakan layanan latar depan ini, gunakan API
alternatif, seperti WorkManager. Secara khusus, daripada menggunakan layanan latar depan
dataSync, pertimbangkan untuk menggunakan API alternatif.
Jika layanan latar depan dataSync aplikasi Anda telah berjalan selama 6 jam dalam
24 jam terakhir, Anda tidak dapat memulai layanan latar depan dataSync lain kecuali pengguna
telah membawa aplikasi Anda ke latar depan (yang akan mereset timer). Jika Anda mencoba untuk
memulai layanan latar depan dataSynclain, sistem akan menampilkan
ForegroundServiceStartNotAllowedException
dengan pesan error seperti "Time limit already exhausted for foreground service
type dataSync".
Pengujian
Untuk menguji perilaku aplikasi, Anda dapat mengaktifkan waktu tunggu sinkronisasi data meskipun aplikasi Anda tidak menargetkan Android 15 (selama aplikasi berjalan di perangkat Android 15). Untuk mengaktifkan waktu tunggu, jalankan perintah adb berikut:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
Anda juga dapat menyesuaikan periode waktu tunggu, untuk memudahkan pengujian perilaku aplikasi saat batas tercapai. Untuk menetapkan periode waktu tunggu baru untuk layanan latar depan dataSync, jalankan perintah adb berikut:
adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds
Untuk menetapkan periode waktu tunggu baru untuk layanan latar depan mediaProcessing, jalankan perintah ini:
adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds