暂停/恢复时libgdx出现ANR错误

时间:2013-11-22 13:43:12

标签: android libgdx

我有一个在Android市场上运行的应用程序,我收到了2个ANR日志。

不同的ANR名称,但位置相同(AndroidGraphics.java:404)。 我不知道该怎么办。 ¿任何人都可以帮助我吗?

谢谢!

堆栈1: ANR keyDispatchingTimedOut

JNI: CheckJNI is off; workarounds are off; pins=0; globals=192 (plus 11 weak)

DALVIK THREADS:
(mutexes: tll=0 tsl=0 tscl=0 ghl=0)

"main" prio=5 tid=1 WAIT
| group="main" sCount=1 dsCount=0 obj=0x42058578 self=0x41522120
| sysTid=15043 nice=0 sched=0/0 cgrp=apps handle=1074204668
| state=S schedstat=( 0 0 0 ) utm=1257 stm=809 core=2
at java.lang.Object.wait(Native Method)
- waiting on <0x42928d90> (a java.lang.Object)
at java.lang.Object.wait(Object.java:364)
at com.badlogic.gdx.backends.android.AndroidGraphics.pause(AndroidGraphics.java:404)
at com.badlogic.gdx.backends.android.AndroidApplication.onPause(AndroidApplication.java:217)
at com.packetname.gameName.MainActivity.onPause(MainActivity.java:124)
at android.app.Activity.performPause(Activity.java:5235)
at android.app.Instrumentation.callActivityOnPause(Instrumentation.java:1233)
at android.app.ActivityThread.performPauseActivity(ActivityThread.java:3050)
at android.app.ActivityThread.performPauseActivity(ActivityThread.java:3019)
at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:2997)
at android.app.ActivityThread.access$800(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1267)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5103)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)

Stack 2: ANR意图广播{act = android.intent.action.SCREEN_OFF flg = 0x50000010}

    DALVIK THREADS:
    (mutexes: tll=0 tsl=0 tscl=0 ghl=0)

"main" prio=5 tid=1 WAIT
| group="main" sCount=1 dsCount=0 obj=0x40ba7568 self=0x40b97a18
| sysTid=1566 nice=0 sched=0/0 cgrp=apps handle=1075324464
| schedstat=( 267164153 509750763 1051 ) utm=17 stm=9 core=1
at java.lang.Object.wait(Native Method)
- waiting on <0x411f0908> (a java.lang.Object)
at java.lang.Object.wait(Object.java:364)
at com.badlogic.gdx.backends.android.AndroidGraphics.pause(AndroidGraphics.java:404)
at com.badlogic.gdx.backends.android.AndroidApplication.onPause(AndroidApplication.java:217)
at com.packetname.gameName.MainActivity.onPause(MainActivity.java:102)
at android.app.Activity.performPause(Activity.java:5106)
at android.app.Instrumentation.callActivityOnPause(Instrumentation.java:1225)
at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2825)
at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2794)
at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:2772)
at android.app.ActivityThread.access$800(ActivityThread.java:130)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1206)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:0)

渲染代码路径中的某些内容正在挂起,或者只是花费太长时间。

您显示的堆栈跟踪是针对主要的android线程,在Libgdx中,与运行libgdx代码的渲染线程不同。见https://code.google.com/p/libgdx/wiki/TheArchitecture#The_Application。暂停路径中发生的事情是

  1. Android要求主线程暂停
  2. 主线程要求libgdx渲染线程暂停(参见onPause at AndroidApplication.java line 214),这会调用graphics.pause()
  3. graphics.pause()(请参阅AndroidGraphics.java line 409),设置pause标志并旋转,直到标志清除为止。
  4. 渲染循环中的渲染线程清除pause标志(请参阅AndroidGraphics中的onDrawFrame)。
  5. 如果你的渲染循环卡在某处,那么暂停标志将永远不会被清除,并且主线程将不会被唤醒,Android将会杀死你的应用。

    所以你展示的回溯只包括前三个步骤(在Android线程上),而不是有趣的回溯。

    希望崩溃报告包含系统中其他线程的回溯。

    如果这是罕见的崩溃,可能是你的渲染循环在某处挂起(与暂停代码无关),用户生气,并尝试切换上下文,Android尝试暂停系统,然后Android生气并杀死你的应用程序。这就是为什么你不应该在渲染线程上做任何非常慢的事情(比如等待网络响应或从慢速存储中读取很多东西):用户可能随时暂停,并期望渲染线程快速执行暂停操作。