Android 7.x 上的 Samsung Galaxy 设备出现大量 OutOfMemoryError
A lot of OutOfMemoryError from Samsung Galaxy devices on Android 7.x
我在 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.RuntimeException
在 android.app.ActivityThread.performLaunchActivity
java.lang.OutOfMemoryError
在 java.lang.StringFactory.newStringFromBytes
java.lang.OutOfMemoryError
在 libcore.util.CharsetUtils.toUtf8Bytes
java.lang.OutOfMemoryError
在 java.lang.StringFactory.newStringFromChars
java.lang.OutOfMemoryError
在 java.lang.StringBuilder.toString
java.lang.OutOfMemoryError
在 java.lang.StringFactory.newStringFromChars
Android 版本:7.0、7.1 很少有 6.0
我不知道为什么会在这些设备上发生这种情况,我不知道如何调试这些报告,而且我在 Whosebug 或任何其他来源上都没有发现任何类似的内容。有帮助吗?
编辑,一些堆栈跟踪:
三星 Galaxy A5(2016) (a5xelte),2048MB 内存,Android7.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 内存,Android7.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)
让我们分段查看最后的堆栈跟踪:
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[]
。要么你的堆 space 非常短,要么是一个相当大的字符串。
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()
。这表明某些东西正在调用 loadDataWithBaseURL()
,并且 URL 相当大。 data:
URL 是一种可能性。
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
。
因此,检查您的广告网络库并确保您使用的是您可以支持的最新和最好的。幸运的是,这是他们在他们的库中修复的一个错误。
我不想这样解决,但似乎可以通过添加
来解决
largeHeap="true"
进入我的清单。
我发现了什么:Samsung Galaxy 设备的内存未经过 Samsung 优化(Galaxy A5 2016 有 2GB RAM。这绰绰有余,但在 Firebase 上我可以看到 OOM,因为堆很少)。因此,我决定一劳永逸地解决问题,并将 largeHeap 设置为 true。我对这个选择并不感到自豪,但它似乎是唯一可行的选择。
结果:所有 OOM 似乎 都消失了,暂时
我在 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.RuntimeException
在android.app.ActivityThread.performLaunchActivity
java.lang.OutOfMemoryError
在java.lang.StringFactory.newStringFromBytes
java.lang.OutOfMemoryError
在libcore.util.CharsetUtils.toUtf8Bytes
java.lang.OutOfMemoryError
在java.lang.StringFactory.newStringFromChars
java.lang.OutOfMemoryError
在java.lang.StringBuilder.toString
java.lang.OutOfMemoryError
在java.lang.StringFactory.newStringFromChars
Android 版本:7.0、7.1 很少有 6.0
我不知道为什么会在这些设备上发生这种情况,我不知道如何调试这些报告,而且我在 Whosebug 或任何其他来源上都没有发现任何类似的内容。有帮助吗?
编辑,一些堆栈跟踪:
三星 Galaxy A5(2016) (a5xelte),2048MB 内存,Android7.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 内存,Android7.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)
让我们分段查看最后的堆栈跟踪:
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[]
。要么你的堆 space 非常短,要么是一个相当大的字符串。
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()
。这表明某些东西正在调用 loadDataWithBaseURL()
,并且 URL 相当大。 data:
URL 是一种可能性。
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
。
因此,检查您的广告网络库并确保您使用的是您可以支持的最新和最好的。幸运的是,这是他们在他们的库中修复的一个错误。
我不想这样解决,但似乎可以通过添加
来解决largeHeap="true"
进入我的清单。
我发现了什么:Samsung Galaxy 设备的内存未经过 Samsung 优化(Galaxy A5 2016 有 2GB RAM。这绰绰有余,但在 Firebase 上我可以看到 OOM,因为堆很少)。因此,我决定一劳永逸地解决问题,并将 largeHeap 设置为 true。我对这个选择并不感到自豪,但它似乎是唯一可行的选择。
结果:所有 OOM 似乎 都消失了,暂时