Я пытаюсь реализовать работника, который обновляет мои данные о погоде каждые 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()
}
}
WorkerFactory:
@HiltAndroidApp
class Application : Application(), Configuration.Provider {
@Inject
lateinit var workerFactory: CustomWorkerFactory
override fun getWorkManagerConfiguration() =
Configuration.Builder()
.setMinimumLoggingLevel(Log.DEBUG)
.setWorkerFactory(workerFactory)
.build()
}
class CustomWorkerFactory @Inject constructor(private val api: WeatherService, private val viewModel: WeatherViewModel): WorkerFactory() {
override fun createWorker(
appContext: Context,
workerClassName: String,
workerParameters: WorkerParameters
): ListenableWorker? = WeatherUpdateWorker(api, appContext, workerParameters, viewModel)
Подробнее здесь: https://stackoverflow.com/questions/790 ... frequently
PeriodicWorkRequest выполняется слишком часто ⇐ Android
Форум для тех, кто программирует под Android
-
Anonymous
1728978231
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()
}
}
WorkerFactory:
@HiltAndroidApp
class Application : Application(), Configuration.Provider {
@Inject
lateinit var workerFactory: CustomWorkerFactory
override fun getWorkManagerConfiguration() =
Configuration.Builder()
.setMinimumLoggingLevel(Log.DEBUG)
.setWorkerFactory(workerFactory)
.build()
}
class CustomWorkerFactory @Inject constructor(private val api: WeatherService, private val viewModel: WeatherViewModel): WorkerFactory() {
override fun createWorker(
appContext: Context,
workerClassName: String,
workerParameters: WorkerParameters
): ListenableWorker? = WeatherUpdateWorker(api, appContext, workerParameters, viewModel)
Подробнее здесь: [url]https://stackoverflow.com/questions/79086280/periodicworkrequest-running-too-frequently[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия