小编典典

Android服务停止

java

我已经到了秃顶几步之遥…

我正在尝试运行一项服务,该服务将检查我工作中的服务器是否正在运行。应该每5分钟执行一次。

我经历过TimerTask,ScheduledExecutorService,最后是Handler。他们都工作了好几个小时,除了一些不准确的地方外,还有1-5分钟的时间,然后突然,“计时器”就停止了发射。

现在,我已经了解到,如果Scheduler遇到未捕获的异常,它将停止运行,而且我敢肯定TimerTask也是如此-但是检查日志文件,根本没有任何异常…

今天下班回家时,我决定对Handler进行实验。

我创建了2个处理程序,其中一个将运行用于检查服务器的代码,并一次增加一个int。另一个将只记录上述int的值,以便在遇到异常时不停止(我看不出它会如何)。

它运行良好,通常会出现1-5分钟的误差,持续几个小时然后停止,以下是日志的最后几行:

02-07 20:03:25.892 D/dalvikvm(  992): GC_EXPLICIT freed 192K, 53% free 4295K/9031K, external 3755K/4825K, paused 114ms
02-07 20:03:35.572 D/dalvikvm( 5472): GC_EXPLICIT freed <1K, 54% free 2895K/6279K, external 2002K/2137K, paused 61ms
02-07 20:04:42.212 V/ServerChecker(12568): Timer triggered
02-07 20:04:42.212 V/ServerChecker(12568): Checking: linux15
02-07 20:04:44.152 V/ServerChecker(12568): Checked: linux15
02-07 20:04:44.152 V/ServerChecker(12568): Checking: linux1
02-07 20:04:44.462 V/ServerChecker(12568): Checked: linux1
02-07 20:04:44.462 V/ServerChecker(12568): Checking: linux12
02-07 20:04:44.762 V/ServerChecker(12568): Checked: linux12
02-07 20:04:44.762 V/ServerChecker(12568): Checking: linux9
02-07 20:04:45.072 V/ServerChecker(12568): Checked: linux9
02-07 20:04:45.072 V/ServerChecker(12568): Checking: linux14
02-07 20:04:45.382 V/ServerChecker(12568): Checked: linux14
02-07 20:04:45.382 V/ServerChecker(12568): Test timer triggered: 13
02-07 20:05:01.002 E/InputDispatcher(  223): channel '406cefc8 com.n04dev.serverchecker/com.n04dev.serverchecker.ServerChecker (server)' ~ Consumer closed input channel or an error occurred.  events=0x8
02-07 20:05:01.002 E/InputDispatcher(  223): channel '406cefc8 com.n04dev.serverchecker/com.n04dev.serverchecker.ServerChecker (server)' ~ Channel is unrecoverably broken and will be disposed!
02-07 20:05:08.932 D/dalvikvm(12842): GC_EXPLICIT freed 73K, 51% free 2641K/5379K, external 2002K/2137K, paused 37ms
02-07 20:05:09.132 D/dalvikvm(  185): GC_EXPLICIT freed 11K, 53% free 2554K/5379K, external 2002K/2137K, paused 96ms
02-07 20:05:12.022 D/dalvikvm(  185): GC_EXPLICIT freed <1K, 53% free 2554K/5379K, external 2002K/2137K, paused 164ms
02-07 20:05:12.062 D/dalvikvm(  185): GC_EXPLICIT freed <1K, 53% free 2554K/5379K, external 2002K/2137K, paused 36ms
02-07 20:05:18.612 D/dalvikvm(12852): GC_EXPLICIT freed 59K, 52% free 2596K/5379K, external 2002K/2137K, paused 72ms

我真的希望你们对我做错了什么有所了解。我已经用了好几个星期了。尝试不同的计时器,让计时器尝试捕获“主”计时器,然后重新启动它,但是没有运气,正如我的上一个实验所示,它似乎并没有计时器有问题..我认为..


阅读 214

收藏
2020-11-13

共1个答案

小编典典

我经历过TimerTask,ScheduledExecutorService,最后是Handler。他们都工作了好几个小时,除了一些不准确的地方外,还有1-5分钟的时间,然后突然,“计时器”就停止了发射。

当然。这些都不是专为您的目的而设计的,因为它们既不会使设备保持清醒状态,也无法与Android框架完美配合。在RAM
24x7中提供服务只是为了标记时间的流逝是浪费的,并且Android在关闭诸如此类的永久性服务时,每次传递版本时都会变得更加积极。

使用AlarmManager设置您的日程安排和IntentService做实际的工作。它会IntentService自动为您提供网络I /
O的后台线程,并在工作完成后自动关闭服务。

如果您打算即使设备进入睡眠状态也要发生这种情况,请_WAKEUP通过AlarmManager和和WakefulIntentService(或类似的方式)使用警报。

2020-11-13