And*_*Guy 7 crash android out-of-memory crash-reports google-play-console
我在Google Play商店中有一个有效的应用.几个月后,我在Play Console上收到了很多奇怪的崩溃报告.
由于我无法粘贴所有数据(有很多崩溃报告),我试图展示一个很好的总结.详细信息请求.
受影响最大的设备:
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.newStringFromCharsAndroid版本:7.0,7.1和很少6.0
我不知道为什么会在这些设备上发生这种情况,我不知道如何调试这些报告,我在StackOverflow或任何其他来源上找不到类似的东西.有帮助吗?
编辑,一些堆栈跟踪:
三星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)
Run Code Online (Sandbox Code Playgroud)
三星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)
Run Code Online (Sandbox Code Playgroud)
三星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)
Run Code Online (Sandbox Code Playgroud)
编辑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)
Run Code Online (Sandbox Code Playgroud)
本来不想这样解决的,不过好像可以通过添加来解决
largeHeap="true"
Run Code Online (Sandbox Code Playgroud)
进入我的清单。
我发现了什么:三星 Galaxy 设备的内存被三星优化得很差(Galaxy A5 2016 有 2GB 的 RAM。这已经足够了,但在 Firebase 上我可以看到 OOM,因为堆很少)。因此,我决定一劳永逸地解决问题,并将 largeHeap 设置为 true。我并不为这个选择感到自豪,但它似乎是唯一可行的。
结果:目前所有的 OOM似乎都消失了
| 归档时间: |
|
| 查看次数: |
2310 次 |
| 最近记录: |