跟踪发布前报告中报告的错误 - java.lang.NullPointerException - android.accounts.Account

时间:2021-01-27 19:52:21

标签: android

我最近在 Play 商店中更新了我的第一个 Android 应用,并且发布前报告报告了特定设备上的一个错误。提供的堆栈跟踪如下:

FATAL EXCEPTION: main
Process: com.google.android.gm, PID: 9714
java.lang.NullPointerException: Attempt to invoke virtual method 'android.accounts.Account com.android.mail.providers.Account.b()' on a null object reference
    at dgg.Z(PG:3)
    at dgg.onPrepareOptionsMenu(PG:6)
    at com.google.android.gm.ComposeActivityGmail.onPrepareOptionsMenu(PG:1)
    at android.app.Activity.onPreparePanel(Activity.java:4137)
    at gn.onPreparePanel(PG:2)
    at vz.onPreparePanel(Unknown Source:2)
    at tm.onPreparePanel(PG:3)
    at tv.a(PG:192)
    at tv.f(PG:7)
    at tc.run(PG:2)
    at android.os.Handler.handleCallback(Handler.java:883)
    at android.os.Handler.dispatchMessage(Handler.java:100)
    at android.os.Looper.loop(Looper.java:237)
    at android.app.ActivityThread.main(ActivityThread.java:8016)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:496)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1076)

问题是我希望在上面的跟踪中看到我的一个文件和一个行号,但没有,所以我不知道如何追踪这个错误的原因。

跟踪提到了“ComposeActivityGmail”。我的应用中唯一与 Gmail 相关的地方是我的设置菜单中的一个选项,它使用以下代码启动“发送电子邮件”意图,所以我猜错误就在这里。

public class SettingsMenuFragment extends PreferenceFragmentCompat {
    @Override
    public void onCreatePreferences(Bundle bundle, String s) {

        addPreferencesFromResource(R.xml.app_preferences);
        Preference feedbackPreference = findPreference("keyFeedback");

        Objects.requireNonNull(feedbackPreference).setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
            @Override
            public boolean onPreferenceClick(Preference preference) {

                Intent intent = new Intent(Intent.ACTION_SENDTO);
                intent.setData(Uri.parse("mailto:")); // only email apps should handle this
                intent.putExtra(Intent.EXTRA_EMAIL, new String[]{"fakeemail@gmail.com"});
                intent.putExtra(Intent.EXTRA_SUBJECT, "Fake Feedback");
                if (intent.resolveActivity(requireActivity().getPackageManager()) != null) {
                    startActivity(intent);
                }
                return true;
            }
        });

有没有人对如何更好地理解堆栈跟踪有任何建议,或者以下代码片段中可能有什么问题?

更新 所以在预发布报告中遇到问题的设备是三星。我自己采购了一台三星设备并设法重现了这个问题。当我点击反馈首选项时,电子邮件客户端选择弹出窗口打开,但我的应用程序死了。然后我将手机插入我的笔记本电脑并在 android studio 中以调试模式运行相同的代码库,但它运行良好。再次从 Play 商店安装了该应用程序(仍然与以前的版本相同),现在它可以正常工作了。好纠结!

0 个答案:

没有答案