2017-06-01 338 views
0

此代码在后台线程上运行:Thread.sleep()方法会导致ANR Android中

@Override 
public void run() { 
    while (true) { 
     a = a+1; 

     try { 
      Thread.sleep(100); 
     } 
     catch (Throwable t) { 
      Log.e("","", t); 
     }   
    } 
} 

在开发者控制台,我看到ANR报告:

ANR输入调度;超时(正在等待发送因为 触摸窗口尚未处理完该经500.0ms前交付给它一定的输入事件 非关键事件。)

"myThread" prio=5 tid=7 SUSPENDED 
    | group="main" sCount=1 dsCount=0 obj=0x11111111 self=0x22222222 
    | sysTid=11111 nice=0 sched=0/0 cgrp=[fopen-error:2] handle=333333333 
    | state=S schedstat=(0 0 0) utm=2 stm=3 core=1 
    at java.lang.VMThread.sleep (Native Method) 
    at java.lang.Thread.sleep (Thread.java:1013) 
    at java.lang.Thread.sleep (Thread.java:995) 
    at com.example.MyThread.run (MyThread.java:123) 

我该如何解决这个ANR?

+0

尽管为什么你想让你的线程继续睡眠 –

+0

发布完整的代码不,它在工作线程上,并且不能引起ARN。你的错误来自另一个代码块。 –

回答

0

问题是您在while(true)循环内发出增量命令。

相关问题