java - 致命异常:java.lang.OutOfMemoryError: EnsureLocalCapacity (FileInputStream.open0, android.graphics.Typeface.getFullFlipFont)
问题描述
将 BuildTools 从 23 升级到 27 后,我遇到了崩溃问题。
我在分析器中检查了 RAM 使用情况——那里没有异常。应用程序有时在后台崩溃,有时在前台崩溃,在不同的活动中(崩溃完全是不确定的),它似乎不依赖于内存使用情况(能够在使用 350mb 时崩溃,就像使用 200mb 一样)
我还安装了“square/leakcanary”来查找任何内存泄漏,但那里什么也没有……
似乎是加载本机字体的问题。我不在此应用程序中使用自定义字体。我设法使三星 S9 和三星 S5 上的应用程序崩溃。有任何想法吗?:(
谢谢你的帮助!
堆栈跟踪:
2018-10-05 08:09:04.740 20542-20542/pl.chillout.debug E/AndroidRuntime: FATAL EXCEPTION: main
Process: pl.chillout.debug, PID: 20542
java.lang.OutOfMemoryError: EnsureLocalCapacity
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:200)
at java.io.FileInputStream.<init>(FileInputStream.java:150)
at android.graphics.Typeface.getFullFlipFont(Typeface.java:1275)
at android.graphics.Typeface.getFontPathFlipFont(Typeface.java:1220)
at android.graphics.Typeface.SetFlipFonts(Typeface.java:1413)
at android.graphics.Typeface.SetAppTypeFace(Typeface.java:1547)
at android.app.Activity.onCreate(Activity.java:1020)
at android.support.v4.app.SupportActivity.onCreate(SupportActivity.java:66)
at android.support.v4.app.FragmentActivity.onCreate(FragmentActivity.java:321)
at android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:84)
at pl.chillout.redesign.activity.BaseDrawerActivity.onCreate(BaseDrawerActivity.java:45)
at pl.chillout.redesign.activity.ChilloutActivity.onCreate(ChilloutActivity.java:115)
at android.app.Activity.performCreate(Activity.java:7174)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1220)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2908)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3030)
at android.app.ActivityThread.-wrap11(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1696)
at android.os.Handler.dispatchMessage(Handler.java:105)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6938)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:327)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1374)
解决方案
实际上,我终于设法通过将 BuildTools 从版本 27 升级到 28 来完全“修复”这个崩溃(正如我在问题评论部分提到的问题不适用于发布版本)。
推荐阅读
- java - 如何将 Hashmap 数据(可变键/值大小)转储到 Android Studio 中特定内存位置的 .csv 文件中?
- reactjs - 为 chart.js 饼图创建一个道具
- png - 使用 LZ4 压缩位图的最佳实践
- couchbase - 打开存储桶时出错#bucket:无法连接到任何指定的主机(使用 x.509 证书将网关身份验证同步到 Couchbase。)
- sql - 如何删除表中具有空外键引用的所有行?
- c# - 尝试合计支付金额时显示错误值的总和
- ios - 在 xcode11 中为 ios13 获取错误的用户当前位置
- windows-subsystem-for-linux - 无法从 Windows 访问在 WSL2 上运行的 Artemis
- gstreamer - Gstreamer:使用 qtmux 的 moov-recovery 信息?
- css - 在设备尺寸上集中对齐项目 =< 小