Java 我如何追踪哪个图像是我应用程序的杀手?
我有一个正在绘制的图像太大,它杀死了我的应用程序的问题 出现以下错误:Java 我如何追踪哪个图像是我应用程序的杀手?,java,android,image,bitmap,trace,Java,Android,Image,Bitmap,Trace,我有一个正在绘制的图像太大,它杀死了我的应用程序的问题 出现以下错误: java.lang.RuntimeException: Canvas: trying to draw too large (numbernumbernumberbytes) bitmap. 我已经浏览了我的应用程序,并禁用了所有直接加载的大型图像。使用Glide(图像加载库)加载的图像不应该是问题 错误仍然存在,我想知道是否有办法跟踪错误。以准确查看导致问题的图像 有没有办法追踪这个 编辑1: 错误的完整堆栈跟踪: 07-
java.lang.RuntimeException: Canvas: trying to draw too large (numbernumbernumberbytes) bitmap.
我已经浏览了我的应用程序,并禁用了所有直接加载的大型图像。使用Glide(图像加载库)加载的图像不应该是问题
错误仍然存在,我想知道是否有办法跟踪错误。以准确查看导致问题的图像
有没有办法追踪这个
编辑1:
错误的完整堆栈跟踪:
07-07 19:22:21.468 D/AndroidRuntime: Shutting down VM
--------- beginning of crash
07-07 19:22:21.469 E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.linkhubapp, PID: 20097
java.lang.RuntimeException: Canvas: trying to draw too large(132710400bytes) bitmap.
at android.view.DisplayListCanvas.throwIfCannotDraw(DisplayListCanvas.java:260)
at android.graphics.Canvas.drawBitmap(Canvas.java:1420)
at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:545)
at android.widget.ImageView.onDraw(ImageView.java:1286)
at android.view.View.draw(View.java:18318)
at android.view.View.updateDisplayListIfDirty(View.java:17296)
at android.view.View.draw(View.java:18080)
at android.view.ViewGroup.drawChild(ViewGroup.java:3966)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3752)
at android.view.View.updateDisplayListIfDirty(View.java:17291)
at android.view.View.draw(View.java:18080)
at android.view.ViewGroup.drawChild(ViewGroup.java:3966)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3752)
at android.view.View.updateDisplayListIfDirty(View.java:17291)
at android.view.View.draw(View.java:18080)
at android.view.ViewGroup.drawChild(ViewGroup.java:3966)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3752)
at android.view.View.updateDisplayListIfDirty(View.java:17291)
at android.view.View.draw(View.java:18080)
at android.view.ViewGroup.drawChild(ViewGroup.java:3966)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3752)
at android.view.View.updateDisplayListIfDirty(View.java:17291)
at android.view.View.draw(View.java:18080)
at android.view.ViewGroup.drawChild(ViewGroup.java:3966)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3752)
at android.view.View.draw(View.java:18321)
at com.android.internal.policy.DecorView.draw(DecorView.java:919)
at android.view.View.updateDisplayListIfDirty(View.java:17296)
at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:692)
at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:698)
at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:806)
at android.view.ViewRootImpl.draw(ViewRootImpl.java:3121)
at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2917)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2509)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1508)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7084)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:927)
at android.view.Choreographer.doCallbacks(Choreographer.java:702)
at android.view.Choreographer.doFrame(Choreographer.java:638)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:913)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6682)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1520)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1410)
(我正在使用Android Studio)。。。要知道它是哪个图像,需要进行一点调试。请执行以下操作:
就这样 堆栈跟踪的其余部分可能会有帮助。请检查一下,看看这是否有帮助。@Commonware我已经添加了错误的整个堆栈跟踪是什么让你说用Glide加载的图像不应该是个问题~130MB是一个相当大的图像。我没有使用Glide,但如果它提供任何类型的日志记录,请启用它,并查看它是否记录加载大型图像。除了来自
ImageView
的崩溃之外,堆栈跟踪没有任何帮助(我可以理解为什么最初没有包括它)。我想不出还有什么好办法能从中得到更多。如果您在清单中启用了android:largeHeap
,请禁用它,也许您会在某个位置得到一个OutOfMemoryError
,这将帮助您跟踪这个大图像的来源。找出哪个图像的大小正好是132710400字节。这就是你的应用程序的图片。嗨,威尔,谢谢你留下这个答案。我很久以前就发布了这个问题,但是看到这种方法来发现这种bug真的很棒。所以请投你一票:D@Will布芬顿谢谢你!我已经搜索了几个小时,试图调试我的哪一个可抽绳导致了银河S6上的throwIfCannotDraw碰撞。你的解决方案非常有效!我发现肇事者可以拖拉,并据此调整大小,不再发生碰撞!