在 android.graphics.HardwareRenderer.nSyncAndDrawFrame 上出现 ANR 的原因是什么?

9

我已经看到了一些关于这个问题的答案,但它们都非常过时(比如它们谈论非常古老的WebView版本)。

我的应用程序确实使用了WebView,因为它是一个浏览器,并且它也通常使用WebView来显示广告。它还使用ExoPlayer,我认为有些广告也会用ExoPlayer来显示。不幸的是,我没有任何关于这些ANR发生的详细信息,但我知道自从切换广告调解到另一个公司以来,它们发生得更频繁了。

我看到建议禁用硬件加速,但我不明白为什么或者在什么情况下要这样做?对我来说,硬件加速似乎是好事情?

这是ANR的堆栈跟踪:

main (native): tid=1 systid=7983
#00 pc 0x7590c libc.so 
#01 pc 0x795f8 libc.so 
#02 pc 0xda55c libc.so 
#03 pc 0x327d54 libhwui.so 
#04 pc 0x30a2dc libhwui.so 
       at android.graphics.HardwareRenderer.nSyncAndDrawFrame(HardwareRenderer.java)
       at android.graphics.HardwareRenderer.syncAndDrawFrame(HardwareRenderer.java:436)
       at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:658)
       at android.view.ViewRootImpl.draw(ViewRootImpl.java:4664)
       at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:4375)
       at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:3585)
       at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:2340)
       at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:9057)
       at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1040)
       at android.view.Choreographer.doCallbacks(Choreographer.java:864)
       at android.view.Choreographer.doFrame(Choreographer.java:791)
       at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1025)
       at android.os.Handler.handleCallback(Handler.java:938)
       at android.os.Handler.dispatchMessage(Handler.java:99)
       at android.os.Looper.loop(Looper.java:255)
       at android.app.ActivityThread.main(ActivityThread.java:8212)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:632)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1049)

我认为这与线程有关。确保在后台线程中加载数据。如果您的应用程序使用Kotlin,则可以尝试使用协程。 - Tahir Ferli
我认为这是谷歌广告。 - SteelBytes
这个堆栈跟踪中的代码都不是我的。如果它涉及到其他线程,我认为它会出现在许多其他地方,而不仅仅是这个堆栈跟踪中。 - casolorz
不,从来没有。那些带有与你自己无关的堆栈跟踪的ANR非常难以解决。 - casolorz
2个回答

0

我也遇到过这个问题。你可以做两件事情。

步骤 #1

<application>
    ...
    <meta-data
        android:name="com.google.android.gms.ads.flag.OPTIMIZE_INITIALIZATION"
        android:value="true"/>
    <meta-data
        android:name="com.google.android.gms.ads.flag.OPTIMIZE_AD_LOADING"
        android:value="true"/>
</application>

步骤 #2

在后台线程中调用您的原生广告,您可以使用一些协程/线程进行调用,同时在显示时可以将您的线程更新到主线程。


0

我的应用程序也发现了这个ANR。它发生在具有Google广告和音频播放器的页面上。可能是由于Google广告的视频广告与音频播放器之间的交互引起的。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接