我想每 5 分钟安排一次后台服务。我使用 HandlerThread 和 Handler 来管理线程和 JobIntentService 来完成任务。我的代码正在运行到我的表盘的 onCreate 方法中,这是始终显示在我的智能手表上的主应用程序。
该设备是基于 Wear OS 的,当我调试它并且智能手表连接到电缆时,我的代码可以完美运行。但是当我断开智能手表并且表盘进入某种省电模式(= Wear OS 开发人员的环境模式)时,我的问题就开始了:
突然系统没有在指定的时间安排线程,我开始有延迟。我想在每个特定时间运行我的服务。
我不知道我是否应该改用警报管理器。
这是处理程序的代码:
fun manageTestingTaskSchedule() {
val handlerThread = HandlerThread("handler-thread", Process.THREAD_PRIORITY_URGENT_AUDIO)
handlerThread.start()
val handler = Handler(handlerThread.looper)
handler.postAtFrontOfQueue(RunnableTestingTask(this@MyWatchFaceSOSApp, handler))
}
我将最高优先级分配给线程,以免在调度它们时出现延迟。
这是运行服务的线程的代码:
class RunnableTestingTask(val watchfaceContext: Context, val handler: Handler): Runnable {
val TAG = "RunnableTestingTask"
override fun run() {
val currentThread = Thread.currentThread()
Log.i(TAG, "Thread name : " + currentThread.name + " thread priority : " + Process.getThreadPriority(Process.myTid()))
if(WifiConnectivityChecker(watchfaceContext).isConnectedWifi()) {
val sosMsgToGatewayIntent = Intent()
PresenceReportService().enqueueWork(watchfaceContext, sosMsgToGatewayIntent)
} else if(!WifiConnectivityChecker(watchfaceContext).isConnectedWifi()) {
Log.i(TAG, "La conexion WIFI con la pasarela no se ha establecido")
}
handler.postDelayed(this, 300000)
}
}