【发布时间】:2011-02-08 04:35:30
【问题描述】:
我已经到了离秃顶只有几步之遥的地步......
我正在尝试运行一项服务,该服务将检查我工作的服务器是否正在运行。它应该每 5 分钟执行一次。
我经历过 TimerTask、ScheduledExecutorService,最后是 Handler。 他们都“正常”工作了几个小时,除了一些不准确,1-5分钟,然后突然“计时器”停止触发。
现在,我了解到如果调度程序遇到未捕获的异常,它将停止,我确信 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
我查看了关于我的应用的最后两条消息,发现 this thread - 但我看不出这将如何适用于我的情况。
我真的希望你们对我做错了什么有所了解。我已经做了好几个星期了。尝试不同的计时器,让计时器尝试捕捉“主”计时器停止然后重新启动它,但没有运气,正如我上次的实验所示,它似乎不是定时器有问题..我认为..
【问题讨论】:
标签: java android service timer