PeriodicWorkRequest выполняется слишком частоAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 PeriodicWorkRequest выполняется слишком часто

Сообщение Anonymous »

Я пытаюсь реализовать работника, который обновляет мои данные о погоде каждые 1,5 часа. Я использую PeriodicWorkRequestBuilder и указал время, как показано в моем коде:
@RequiresApi(Build.VERSION_CODES.O)
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = ActivityMainBinding.inflate(layoutInflater)
setContentView(binding.root)

val workRequest = PeriodicWorkRequestBuilder(
repeatInterval = 90,
repeatIntervalTimeUnit = TimeUnit.MINUTES,
).setBackoffCriteria(
backoffPolicy = BackoffPolicy.LINEAR,
duration = Duration.ofSeconds(15)
)
.build()

WorkManager.getInstance(applicationContext).enqueueUniquePeriodicWork(
"WeatherUpdateWork",
ExistingPeriodicWorkPolicy.KEEP,
workRequest
)

Однако, когда я проверяю Logcat, мои рабочие журналы показывают, что он выполняется каждые 15 минут. Как это исправить?
Я добавил журналы к своему работнику, чтобы показать время его вызова:
@HiltWorker
class WeatherUpdateWorker @AssistedInject constructor(
private val api: WeatherService,
@Assisted val context: Context,
@Assisted workerParameters: WorkerParameters,
private val viewModel: WeatherViewModel
): CoroutineWorker(context, workerParameters) {
override suspend fun doWork(): Result {

try {
val response = api.getWeather()
viewModel.setWeatherResults(response)

val currentTime = System.currentTimeMillis()
saveLastExecutionTime(currentTime)

Log.d("WeatherWorker", "Success, ${currentTime}")
return Result.success()
} catch (e: Exception) {
Log.d("WeatherWorker", "Error")
return Result.retry()
}
}

private fun saveLastExecutionTime(currentTime: Long) {
val sharedPreferences = context.getSharedPreferences("weather_prefs", Context.MODE_PRIVATE)
sharedPreferences.edit().putLong("last_execution_time", currentTime).apply()
}
}


Подробнее здесь: https://stackoverflow.com/questions/790 ... frequently
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»