首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >引入WebView / AdMob后的AdMob/ webcore错误

引入WebView / AdMob后的AdMob/ webcore错误
EN

Stack Overflow用户
提问于 2014-02-11 23:34:39
回答 1查看 481关注 0票数 0

我刚刚在我的一个活动中添加了一个来自AdMob的AdMob。添加此视图后,活动开始时会出现一些明显的滞后。在LogCat中,我看到以下异常。它不会导致应用程序停止,但显示为警告:

代码语言:javascript
运行
复制
W/webcore(12969): java.lang.Throwable: EventHub.removeMessages(int what = 107) is not supported before the WebViewCore is set up.
W/webcore(12969):   at android.webkit.WebViewCore$EventHub.removeMessages(WebViewCore.java:2207)
W/webcore(12969):   at android.webkit.WebViewCore$EventHub.access$10000(WebViewCore.java:1167)
W/webcore(12969):   at android.webkit.WebViewCore.removeMessages(WebViewCore.java:2454)
W/webcore(12969):   at android.webkit.WebView.sendOurVisibleRect(WebView.java:3383)
W/webcore(12969):   at android.webkit.ZoomManager.setZoomScale(ZoomManager.java:776)
W/webcore(12969):   at android.webkit.ZoomManager.access$1900(ZoomManager.java:60)
W/webcore(12969):   at android.webkit.ZoomManager$PostScale.run(ZoomManager.java:1372)
W/webcore(12969):   at android.os.Handler.handleCallback(Handler.java:608)
W/webcore(12969):   at android.os.Handler.dispatchMessage(Handler.java:92)
W/webcore(12969):   at android.os.Looper.loop(Looper.java:156)
W/webcore(12969):   at android.app.ActivityThread.main(ActivityThread.java:5109)
W/webcore(12969):   at java.lang.reflect.Method.invokeNative(Native Method)
W/webcore(12969):   at java.lang.reflect.Method.invoke(Method.java:511)
W/webcore(12969):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:991)
W/webcore(12969):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:758)
W/webcore(12969):   at dalvik.system.NativeStart.main(Native Method)
W/webcore(12969): java.lang.Throwable: EventHub.removeMessages(int what = 105) is not supported before the WebViewCore is set up.
W/webcore(12969):   at android.webkit.WebViewCore$EventHub.removeMessages(WebViewCore.java:2207)
W/webcore(12969):   at android.webkit.WebViewCore$EventHub.access$10000(WebViewCore.java:1167)
W/webcore(12969):   at android.webkit.WebViewCore.removeMessages(WebViewCore.java:2454)
W/webcore(12969):   at android.webkit.WebView.sendViewSizeZoom(WebView.java:3619)
W/webcore(12969):   at android.webkit.ZoomManager.setZoomScale(ZoomManager.java:782)
W/webcore(12969):   at android.webkit.ZoomManager.access$1900(ZoomManager.java:60)
W/webcore(12969):   at android.webkit.ZoomManager$PostScale.run(ZoomManager.java:1372)
W/webcore(12969):   at android.os.Handler.handleCallback(Handler.java:608)
W/webcore(12969):   at android.os.Handler.dispatchMessage(Handler.java:92)
W/webcore(12969):   at android.os.Looper.loop(Looper.java:156)
W/webcore(12969):   at android.app.ActivityThread.main(ActivityThread.java:5109)
W/webcore(12969):   at java.lang.reflect.Method.invokeNative(Native Method)
W/webcore(12969):   at java.lang.reflect.Method.invoke(Method.java:511)
W/webcore(12969):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:991)
W/webcore(12969):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:758)
W/webcore(12969):   at dalvik.system.NativeStart.main(Native Method)

我还注意到,只有在应用程序第一次运行时才会发生这种情况。当我关闭应用程序并重新启动时,它不会重复。但是初始运行对于用户体验是非常重要的,所以我认为这仍然是一个重要的问题。有什么想法吗?

EN

Stack Overflow用户

回答已采纳

发布于 2014-02-12 22:16:19

几乎可以肯定的是,这与WebView (由AdView使用)创建内部数据库有关,它只在应用程序中首次使用WebView。

它曾经在姜饼(Android2.3)上特别引人注目。

为了减轻压力,我会在应用程序第一次启动时创建一个WebView,同时显示一个启动屏幕。确保在UI线程上创建它(使用处理程序等)。

类似于(在Activity#onCreate中):

代码语言:javascript
运行
复制
runOnUiThread(new Runnable() {
  void run() {
    new WebView(MyActivity.this);
  }
});
票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21715513

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档