代码之家  ›  专栏  ›  技术社区  ›  CantThinkOfAnything

我如何追踪哪个图像是我应用程序的杀手?

  •  1
  • CantThinkOfAnything  · 技术社区  · 7 年前

    出现以下错误:

    java.lang.RuntimeException: Canvas: trying to draw too large (numbernumbernumberbytes) bitmap.
    

    我已经浏览了我的应用程序,并禁用了所有直接加载的大图像。使用Glide加载的图像(图像加载库, https://github.com/bumptech/glide

    错误仍然存在,我想知道是否有办法跟踪错误。以准确查看导致问题的图像。

    有没有办法追踪这个?

    错误的完整堆栈跟踪:

    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)
    
    1 回复  |  直到 7 年前
        1
  •  3
  •   Will Buffington    6 年前

    (我正在使用Android Studio)……要想知道它是哪张图片,需要进行一点调试。执行以下操作:

    1. 首先,运行应用程序并允许其崩溃。
    2. 看看LOGCAT窗口。在那里,您将发现崩溃: “java.lang.RuntimeException:Canvas:试图绘制太大(137080832字节)的位图。”-在下面,查找“at android.graphics.drawable.BitmapDrawable.draw”,它将有一个可单击的右侧链接。它应该是上面异常文本下显示的第一个可单击链接。单击链接。
    3. 帆布drawBitmap(位图,null,mDstRect,paint);

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

    1. 这行代码的断点应该被点击,程序停止,准备好做些什么。将鼠标悬停在代码行中的“位图”上:

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