Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/352.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/178.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 我如何追踪哪个图像是我应用程序的杀手?_Java_Android_Image_Bitmap_Trace - Fatal编程技术网

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)。。。要知道它是哪个图像,需要进行一点调试。请执行以下操作:

  • 首先,运行应用程序并允许其崩溃
  • 看看LOGCAT窗口。在那里,您将发现崩溃: “java.lang.RuntimeException:Canvas:试图绘制太大(137080832字节)的位图。”-在下面,查找“at android.graphics.drawable.BitmapDrawable.draw”,它将有一个指向右侧的可单击链接。它应该是上面异常文本下显示的第一个可单击链接。点击链接
  • 单击该链接应突出显示一行代码,可能如下所示:

    drawBitmap(位图、null、mDstRect、paint)

  • 在该行代码上设置断点。然后使用“调试应用程序”按钮再次运行应用程序。程序将在上述代码行停止。您需要单击“恢复程序”按钮,并记录在程序崩溃之前单击该按钮的次数。然后再次在调试模式下运行应用程序,允许其在该行代码上中断,然后单击“恢复程序”按钮—您以前单击该按钮的次数减去一次。因此,如果我点击了恢复程序按钮4次,以获得崩溃,你会想点击它3次,并停止在那里。这将是导致应用程序崩溃的代码的执行时间

  • 该行代码的断点应该被命中,程序将暂停,准备好执行某些操作。将鼠标悬停在代码行中的“位图”上:

    drawBitmap(位图、null、mDstRect、paint)

  • 不要将鼠标悬停在单词“drawBitmap”上,只需将鼠标悬停在单词“bitmap”上即可。在包含加号(+)和“{Bitmap@#####}”的代码行下方应显示一个黄色的小窗口。单击加号。请注意,在显示的第一行文本的最右侧是一个可单击的链接,其内容为“查看位图”。单击该链接,您将看到应用程序正在尝试加载但未能加载的图片


    就这样

    堆栈跟踪的其余部分可能会有帮助。请检查一下,看看这是否有帮助。@Commonware我已经添加了错误的整个堆栈跟踪是什么让你说用Glide加载的图像不应该是个问题~130MB是一个相当大的图像。我没有使用Glide,但如果它提供任何类型的日志记录,请启用它,并查看它是否记录加载大型图像。除了来自
    ImageView
    的崩溃之外,堆栈跟踪没有任何帮助(我可以理解为什么最初没有包括它)。我想不出还有什么好办法能从中得到更多。如果您在清单中启用了
    android:largeHeap
    ,请禁用它,也许您会在某个位置得到一个
    OutOfMemoryError
    ,这将帮助您跟踪这个大图像的来源。找出哪个图像的大小正好是132710400字节。这就是你的应用程序的图片。嗨,威尔,谢谢你留下这个答案。我很久以前就发布了这个问题,但是看到这种方法来发现这种bug真的很棒。所以请投你一票:D@Will布芬顿谢谢你!我已经搜索了几个小时,试图调试我的哪一个可抽绳导致了银河S6上的throwIfCannotDraw碰撞。你的解决方案非常有效!我发现肇事者可以拖拉,并据此调整大小,不再发生碰撞!