android - Android 7.x 上的 Samsung Galaxy 设备出现大量 OutOfMemoryError

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

我在 Google Play 商店中有一个活跃的应用程序。几个月以来,我在 Play 管理中心收到了很多奇怪的崩溃报告。

由于我无法在此处粘贴所有数据(有很多崩溃报告),所以我试图展示一个很好的摘要。应要求提供详细信息。

受影响最大的设备:

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

ND:与其他设备相比,第一个设备非常关键

崩溃类型:

  • java.lang.RuntimeExceptionandroid.app.ActivityThread.performLaunchActivity
  • java.lang.OutOfMemoryErrorjava.lang.StringFactory.newStringFromBytes
  • java.lang.OutOfMemoryErrorlibcore.util.CharsetUtils.toUtf8Bytes
  • java.lang.OutOfMemoryErrorjava.lang.StringFactory.newStringFromChars
  • java.lang.OutOfMemoryErrorjava.lang.StringBuilder.toString
  • java.lang.OutOfMemoryErrorjava.lang.StringFactory.newStringFromChars

Android 版本:7.0、7.1 和很少有 6.0

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


编辑,一些堆栈跟踪:

三星 Galaxy A5(2016) (a5xelte),2048MB 内存,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 内存,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 内存,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 内存,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)

最佳答案

我不想这样解决,但是似乎可以通过添加来解决

largeHeap="true"

进入我的 list 。

我发现了什么:三星对三星 Galaxy 设备的内存优化不佳(Galaxy A5 2016 有 2GB 内存。这绰绰有余,但在 Firebase 上我可以看到 OOM,因为堆很少)。因此,我决定一劳永逸地解决问题,并将 largeHeap 设置为 true。我对这个选择并不感到自豪,但它似乎是唯一可行的。

结果:所有 OOM 似乎暂时消失了

关于android - Android 7.x 上的 Samsung Galaxy 设备出现大量 OutOfMemoryError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45573920/

相关文章:

java - Android:从 Mysql 填充操作栏微调器

c - 为什么有些 C 程序在调试时可以运行,但在发布时却不行?

java - 关于Android数据库

Android 写入具有错误权限的文件

android - React Native 找不到项目的匹配配置(仅限构建)

iOS Swift - 某些设备上的 EXC_BAD_INSTRUCTION

c++ - Xcode 7 beta 2 不断崩溃

java - 在 Java 中处理内存不足情况的最佳方法是什么?

c# - 简单的连接消耗太多内存 - LINQ

Java:大型 Guava 表对象的序列化失败并出现内存不足错误