尝试在空对象引用上调用虚拟方法'android.content.res.Resources.getAssets()'。

11

发生了什么:

  1. 我从应用商店得到了以下的堆栈跟踪,我所面临的问题是它没有显示哪个类引起了这个崩溃。
  2. 我能理解的是由于我使用的资源引起的。
  3. 我唯一使用资源的地方是在应用程序级别上设置字体。

代码:

private void setDefaultFont() {

        try {
            final Typeface bold = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Bold.ttf");
            final Typeface italic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Italic.ttf");
            final Typeface boldItalic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-BoldItalic.ttf");
            final Typeface regular = Typeface.createFromAsset(getAssets(),"fonts/OpenSans-Regular.ttf");

            Field DEFAULT = Typeface.class.getDeclaredField("DEFAULT");
            DEFAULT.setAccessible(true);
            DEFAULT.set(null, regular);

            Field DEFAULT_BOLD = Typeface.class.getDeclaredField("DEFAULT_BOLD");
            DEFAULT_BOLD.setAccessible(true);
            DEFAULT_BOLD.set(null, bold);

            Field sDefaults = Typeface.class.getDeclaredField("sDefaults");
            sDefaults.setAccessible(true);
            sDefaults.set(null, new Typeface[]{
                    regular, bold, italic, boldItalic
            });

        } catch (NoSuchFieldException e) {
           // logFontError(e);
        } catch (IllegalAccessException e) {
           // logFontError(e);
        } catch (Throwable e) {
            //cannot crash app if there is a failure with overriding the default font!
           // logFontError(e);
        }
    }

来自Appstore的StackTrace:

java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.AssetManager android.content.res.Resources.getAssets()' on a null object reference
at android.app.LoadedApk.getAssets(LoadedApk.java:528)
at android.app.LoadedApk.makeApplication(LoadedApk.java:584)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4526)
at android.app.ActivityThread.access$1500(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

我应该采取什么方法来解决这个问题?


好的,在其他方面,不要再吃掉异常而不记录日志,就像你在现有代码中所做的那样。你知道的,可能正是你需要解决问题的信息被传递给了你,但你却无视它。 - CommonsWare
@黑带……只有一个……奇怪!它总是工作正常,突然出现了这个崩溃。 - Devrath
@CommonsWare...感谢您的输入,是的,我没有处理异常,犯了一个错误。但是如果发生异常,我应该处理什么?我需要设置默认字体或类似的东西吗?...有任何建议吗? - Devrath
4个回答

6

1
尝试单独声明字体样式(不要在同一行中),如下所示, 更改:
final Typeface bold = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Bold.ttf");
final Typeface italic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Italic.ttf");
final Typeface boldItalic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-BoldItalic.ttf");
final Typeface regular = Typeface.createFromAsset(getAssets(),"fonts/OpenSans-Regular.ttf");

to:

final Typeface bold;
final Typeface italic;
final Typeface boldItalic;
final Typeface regular;

bold = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Bold.ttf");
italic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-Italic.ttf");
boldItalic = Typeface.createFromAsset(getAssets(), "fonts/OpenSans-BoldItalic.ttf");
regular = Typeface.createFromAsset(getAssets(),"fonts/OpenSans-Regular.ttf");

有什么区别? - KenIchi

0

并不是一个很好的解决方法,但是(在确保我安装了最新的Android SDK更新之后),我刚刚通过卸载并重新安装我正在测试的应用程序来解决了这个问题。


-1

在调用时添加上下文,应该像这样:-

final Typeface bold = Typeface.createFromAsset(getApplicationContext().getAssets(), "fonts/OpenSans-Bold.ttf");

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接