Android 7.x上三星Galaxy设备的很多OutOfMemoryError

时间:2017-08-08 16:51:15

标签: android crash out-of-memory crash-reports google-play-console

我在Google Play商店中有一个有效的应用。几个月以来,我在Play Console上收到了很多奇怪的崩溃报告。

由于我无法粘贴所有数据(有很多崩溃报告),我试图展示一个很好的总结。详细信息请求。

受影响较大的设备:

  • 三星Galaxy A5 2016(a5xelte)
  • 三星Galaxy S5(klte)
  • 三星Galaxy A5(2017)(a5y17lte)
  • 三星Galaxy Note3(hlte)
  • 三星Galaxy S5 Neo(s5neolte)
  • 三星Galaxy S6(zeroflte)

ND:第一台设备与其他设备相比非常重要

崩溃的类型:

    java.lang.RuntimeException
  • android.app.ActivityThread.performLaunchActivityjava.lang.OutOfMemoryError
  • java.lang.StringFactory.newStringFromBytesjava.lang.OutOfMemoryError
  • libcore.util.CharsetUtils.toUtf8Bytesjava.lang.OutOfMemoryError
  • java.lang.StringFactory.newStringFromCharsjava.lang.OutOfMemoryError
  • java.lang.StringBuilder.toStringjava.lang.OutOfMemoryError
  • java.lang.StringFactory.newStringFromChars

Android版本:7.0,7.1和很少6.0

我不知道为什么会在这些设备上发生这种情况,我不知道如何调试这些报告,我在StackOverflow或任何其他来源上找不到类似的东西。有什么帮助吗?

编辑,有些stacktraces:

三星Galaxy A5(2016)(a5xelte),2048MB RAM,Android 7.0

java.lang.RuntimeException: 
  at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2984)
  at android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:3045)
  at android.app.ActivityThread.-wrap14 (ActivityThread.java)
  at android.app.ActivityThread$H.handleMessage (ActivityThread.java:1642)
  at android.os.Handler.dispatchMessage (Handler.java:102)
  at android.os.Looper.loop (Looper.java:154)
  at android.app.ActivityThread.main (ActivityThread.java:6776)
  at java.lang.reflect.Method.invoke (Method.java)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1496)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1386)

三星Galaxy S6 Edge(zerolte),3072MB RAM,Android 7.0

java.lang.OutOfMemoryError: 
  at java.lang.StringFactory.newStringFromBytes (StringFactory.java:185)
  at java.lang.StringFactory.newStringFromBytes (StringFactory.java:63)
  at android.util.Base64.encodeToString (Base64.java:456)
  at org.chromium.android_webview.AwContents.loadDataWithBaseURL (AwContents.java:428)
  at com.android.webview.chromium.WebViewChromium.loadDataWithBaseURL (WebViewChromium.java:188)
  at android.webkit.WebView.loadDataWithBaseURL (WebView.java:1015)
  at com.google.android.gms.ads.internal.webview.p.loadDataWithBaseURL (p.java:131)
  at com.google.android.gms.ads.internal.webview.o.loadDataWithBaseURL (o.java:104)
  at com.google.android.gms.ads.internal.renderer.i.a (i.java:8)
  at com.google.android.gms.ads.internal.renderer.a.c (a.java:35)
  at com.google.android.gms.ads.internal.renderer.g.a (g.java:11)
  at com.google.android.gms.ads.internal.zzk.run (zzk.java:28)
  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 (Method.java)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1520)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1410)

三星Galaxy A5(2016)(a5xelte),2048MB RAM,Android 7.0

java.lang.OutOfMemoryError: 
  at libcore.util.CharsetUtils.toUtf8Bytes (CharsetUtils.java)
  at java.lang.String.getBytes (String.java:879)
  at java.lang.String.getBytes (String.java:851)
  at org.chromium.android_webview.AwContents.loadDataWithBaseURL (AwContents.java:428)
  at com.android.webview.chromium.WebViewChromium.loadDataWithBaseURL (WebViewChromium.java:188)
  at android.webkit.WebView.loadDataWithBaseURL (WebView.java:1015)
  at com.google.android.gms.ads.internal.webview.p.loadDataWithBaseURL (p.java:131)
  at com.google.android.gms.ads.internal.webview.o.loadDataWithBaseURL (o.java:104)
  at com.google.android.gms.ads.internal.renderer.i.a (i.java:8)
  at com.google.android.gms.ads.internal.renderer.a.c (a.java:35)
  at com.google.android.gms.ads.internal.renderer.g.a (g.java:11)
  at com.google.android.gms.ads.internal.zzk.run (zzk.java:28)
  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:6776)
  at java.lang.reflect.Method.invoke (Method.java)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1496)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1386)

编辑2 :我更新了firebase-ads的依赖关系,但我仍然遇到了相同的崩溃问题。另外,我在这个版本中有一个新的崩溃类型:

三星Galaxy A5(2016)(a5xelte),2048MB RAM,Android 7.0

java.lang.InternalError: 
  at java.lang.Thread.nativeCreate (Thread.java)
  at java.lang.Thread.start (Thread.java:731)
  at java.util.concurrent.ThreadPoolExecutor.addWorker (ThreadPoolExecutor.java:941)
  at java.util.concurrent.ThreadPoolExecutor.processWorkerExit (ThreadPoolExecutor.java:1009)
  at java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1151)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:607)
  at java.lang.Thread.run (Thread.java:762)

2 个答案:

答案 0 :(得分:4)

让我们分段看看最后一个堆栈跟踪:

java.lang.OutOfMemoryError: 
  at libcore.util.CharsetUtils.toUtf8Bytes (CharsetUtils.java)
  at java.lang.String.getBytes (String.java:879)
  at java.lang.String.getBytes (String.java:851)

因此,爆炸的具体问题是将String转换为byte[]。你的堆空间非常短,或者是一个相当大的字符串。

  at org.chromium.android_webview.AwContents.loadDataWithBaseURL (AwContents.java:428)
  at com.android.webview.chromium.WebViewChromium.loadDataWithBaseURL (WebViewChromium.java:188)
  at android.webkit.WebView.loadDataWithBaseURL (WebView.java:1015)

所以,在这里,我们通过String看到WebView的内容是loadDataWithBaseURL()。这表明某些内容正在使用相当大的URL调用loadDataWithBaseURL()data:网址是一种可能性。

  at com.google.android.gms.ads.internal.webview.p.loadDataWithBaseURL (p.java:131)
  at com.google.android.gms.ads.internal.webview.o.loadDataWithBaseURL (o.java:104)
  at com.google.android.gms.ads.internal.renderer.i.a (i.java:8)
  at com.google.android.gms.ads.internal.renderer.a.c (a.java:35)
  at com.google.android.gms.ads.internal.renderer.g.a (g.java:11)
  at com.google.android.gms.ads.internal.zzk.run (zzk.java:28)

这里,我们有六行都来自同一个Java包。 com.google.android.gms是大多数Play服务的顶级软件包,因此com.google.android.gms.ads可能是其广告库之一。我没有使用太多的Play服务,所以我不确切知道他们仍然拥有哪些广告网络品牌以及哪个({)}映射到com.google.android.gms.ads

因此,请检查您的广告网络库,确保您拥有可支持的最新和最好的广告网络库。幸运的是,这是一个他们在图书馆的某个地方修复的错误。

答案 1 :(得分:4)

我不想以这种方式解决,但似乎通过添加来解决

largeHeap="true"

进入我的清单。

我弄清楚:三星Galaxy设备的内存很难被三星优化(Galaxy A5 2016有2GB内存。这已经足够了,但在Firebase上我可以看到OOM因为堆很少)。所以,我决定一劳永逸地解决问题,并将largeHeap设置为true。我并不为这种选择感到自豪,但它似乎是唯一可行的选择。

结果:所有OOM 似乎已经消失,现在