使用traces.txt了解ANR错误

时间:2013-12-10 14:01:28

标签: java android trace android-anr-dialog

我的应用程序中有一个anr后按一个按钮打开一个为我的电池创建图表的活动。我从不使用traces.txt所以我不知道在这个错误中我要看什么:

----- pid 502 at 2013-12-10 14:29:15 -----
Cmd line: com.dd.batterystats

JNI: CheckJNI is off; workarounds are off; pins=0; globals=276

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

"main" prio=5 tid=1 SUSPENDED
  | group="main" sCount=1 dsCount=0 obj=0x41571ca8 self=0x414ab408
  | sysTid=502 nice=0 sched=0/0 cgrp=apps handle=1074172244
  | state=S schedstat=( 57059843673 4570148676 34483 ) utm=5671 stm=34 core=1
  at org.achartengine.chart.TimeChart.getXLabels(TimeChart.java:~190)
  at org.achartengine.chart.XYChart.draw(XYChart.java:314)
  at org.achartengine.GraphicalView.onDraw(GraphicalView.java:166)
  at android.view.View.draw(View.java:14465)
  at android.view.View.getDisplayList(View.java:13362)
  at android.view.View.getDisplayList(View.java:13404)
  at android.view.View.draw(View.java:14182)
  at android.view.ViewGroup.drawChild(ViewGroup.java:3103)
  at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2940)
  at android.view.View.getDisplayList(View.java:13357)
  at android.view.View.getDisplayList(View.java:13404)
  at android.view.View.draw(View.java:14182)
  at android.view.ViewGroup.drawChild(ViewGroup.java:3103)
  at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2940)
  at android.view.View.draw(View.java:14468)
  at com.android.internal.widget.ActionBarOverlayLayout.draw(ActionBarOverlayLayout.java:381)
  at android.view.View.getDisplayList(View.java:13362)
  at android.view.View.getDisplayList(View.java:13404)
  at android.view.View.draw(View.java:14182)
  at android.view.ViewGroup.drawChild(ViewGroup.java:3103)
  at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2940)
  at android.view.View.draw(View.java:14468)
  at android.widget.FrameLayout.draw(FrameLayout.java:472)
  at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:2326)
  at android.view.View.getDisplayList(View.java:13362)
  at android.view.View.getDisplayList(View.java:13404)
  at android.view.HardwareRenderer$GlRenderer.buildDisplayList(HardwareRenderer.java:1570)
  at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1449)
  at android.view.ViewRootImpl.draw(ViewRootImpl.java:2381)
  at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2253)
  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1883)
  at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1000)
  at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5670)
  at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
  at android.view.Choreographer.doCallbacks(Choreographer.java:574)
  at android.view.Choreographer.doFrame(Choreographer.java:544)
  at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
  at android.os.Handler.handleCallback(Handler.java:733)
  at android.os.Handler.dispatchMessage(Handler.java:95)
  at android.os.Looper.loop(Looper.java:136)
  at android.app.ActivityThread.main(ActivityThread.java:5017)
  at java.lang.reflect.Method.invokeNative(Native Method)
  at java.lang.reflect.Method.invoke(Method.java:515)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
  at dalvik.system.NativeStart.main(Native Method)

我要看的那条线在哪里?这是错误!? 编辑:我已更新构建路径,现在我收到此错误:

12-10 15:30:22.036: E/InputEventReceiver(15922): Exception dispatching input event.
12-10 15:30:22.036: E/AndroidRuntime(15922): FATAL EXCEPTION: main
12-10 15:30:22.036: E/AndroidRuntime(15922): Process: com.dd.batterystats, PID: 15922
12-10 15:30:22.036: E/AndroidRuntime(15922): java.lang.NullPointerException
12-10 15:30:22.036: E/AndroidRuntime(15922):    at org.achartengine.chart.XYChart.toRealPoint(XYChart.java:877)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at org.achartengine.tools.Pan.apply(Pan.java:74)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at org.achartengine.TouchHandler.handleTouch(TouchHandler.java:119)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at org.achartengine.GraphicalView.onTouchEvent(GraphicalView.java:300)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.View.dispatchTouchEvent(View.java:7706)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2216)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1959)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2216)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1959)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2216)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1959)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2068)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1515)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.app.Activity.dispatchTouchEvent(Activity.java:2458)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2016)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.View.dispatchPointerEvent(View.java:7886)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:3954)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:3833)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3399)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3449)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3418)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:3525)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3426)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:3582)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3399)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3449)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3418)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3426)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3399)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:5602)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:5582)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:5553)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:5682)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:185)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.InputEventReceiver.nativeConsumeBatchedInputEvents(Native Method)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.InputEventReceiver.consumeBatchedInputEvents(InputEventReceiver.java:176)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl.doConsumeBatchedInput(ViewRootImpl.java:5655)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.ViewRootImpl$ConsumeBatchedInputRunnable.run(ViewRootImpl.java:5701)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.Choreographer.doCallbacks(Choreographer.java:574)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.Choreographer.doFrame(Choreographer.java:542)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.os.Handler.handleCallback(Handler.java:733)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.os.Handler.dispatchMessage(Handler.java:95)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.os.Looper.loop(Looper.java:136)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at android.app.ActivityThread.main(ActivityThread.java:5017)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at java.lang.reflect.Method.invokeNative(Native Method)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at java.lang.reflect.Method.invoke(Method.java:515)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
12-10 15:30:22.036: E/AndroidRuntime(15922):    at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:0)

您需要学习阅读Java堆栈跟踪,它非常简单且非常有用。我有一个small blog post about this,也许对你有用。

在第二种情况下,错误为java.lang.NullPointerException,发生在org.achartengine.chart.XYChart.toRealPoint(XYChart.java:877)。这意味着您在该文件和该行上有一个空引用。