知道是什么导致android.graphics.HardwareRenderer.nSyncAndDrawFrame上的



我已经看到了一些关于这方面的问题,但它们都非常过时(就像他们谈论的是非常旧的WebView版本(。

我的应用程序确实使用WebView,因为它是一个浏览器,它也有广告,他们通常也使用WebView。它还使用了ExoPlayer,我认为一些广告也显示了ExoPPlayer。不幸的是,我不知道这些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)

我的应用程序也能找到这个anr。它发生在有谷歌广告和音频播放器的页面上。可能是谷歌广告的视频广告和音频播放器之间的互动造成的。

我也面临过这种情况。你可以做两件事。

步骤#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

在后台线程上调用您的Native Ads,您可以使用一些Coroutines/Threads进行调用,同时显示您可以将线程更新为主线程。

最新更新