我最近在 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 商店安装了该应用程序(仍然与以前的版本相同),现在它可以正常工作了。好纠结!