web-dev-qa-db-ja.com

nullオブジェクト参照で仮想メソッド 'Android.content.res.AssetManager Android.content.res.Resources.getAssets()'を呼び出そうとしました

何が起こっている:

  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)

これを解決するには、どのようなアプローチを取る必要がありますか?

10
Devrath

これは、同じスタックトレースを持つLollipopデバイスからも見られましたが、独自のコードへの参照もありませんでした。不完全なアプリの更新に起因するプラットフォームのバグのようです。 https://code.google.com/p/Android/issues/detail?id=56296 を参照してください。

6
mattlaabs

次のように、フォントスタイルを個別に(同じ行ではなく)宣言してみてください。

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");

に:

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");
1
Meqdad

優れた回避策ではありませんが、(最新のAndroid SDKアップデートがインストールされていることを確認した後)テストしていたアプリをアンインストールして再インストールすることで、これを解決できました。

0
dstrube