我正在尝试创建一个Android应用程序,但遇到了以下问题:
当我按菜单按钮时,该应用程序会在某些手机上崩溃。让我先给您一些详细信息。
请注意,此代码是从Android Studio生成的。
到目前为止,我尝试过:
- 尝试查看具有问题的文件来自sdk源(API级别16和21),但它们与堆栈跟踪不相关(堆栈跟踪中显示的行指向一个不合理的位置)。 - 尝试安装XPosed修复Google PlayStore崩溃的菜单按钮错误。这里也没有找到解决方法。 - 在firefox的bugtracking系统中找到了一个类似的错误报告,因此我尝试安装Firefox并查看当我按Menu按钮时它是否会在我的手机上崩溃; firefox并没有崩溃。(Link to firefox's bug)
以下是LogCat中的堆栈跟踪:
当我按菜单按钮时,该应用程序会在某些手机上崩溃。让我先给您一些详细信息。
- 该错误仅在LG Optimus L3 II e430上出现,并且使用Android 4.1.2(迄今已在其他四部手机上测试)
- 应用程序从闪屏开始,没有操作栏。此时,菜单按钮只是没有任何作用。
- 通过简单的触摸,我们跳过闪屏,进入实现ActionBar活动和具有导航抽屉的主要活动。
- 从这一点开始,在我尝试点击菜单按钮时,应用程序就会崩溃。
这是菜单的布局和onCreateOptionsMenu函数:
res/menu/main.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item android:id="@+id/action_settings"
android:title="@string/action_settings"
android:orderInCategory="100"
app:showAsAction="never" />
</menu>
来自MainActivity.java的部分
@Override
public boolean onCreateOptionsMenu(Menu menu) {
if (!mNavigationDrawerFragment.isDrawerOpen()) {
// Only show items in the action bar relevant to this screen
// if the drawer is not showing. Otherwise, let the drawer
// decide what to show in the action bar.
getMenuInflater().inflate(R.menu.main, menu);
restoreActionBar();
return true;
}
return super.onCreateOptionsMenu(menu);
}
请注意,此代码是从Android Studio生成的。
到目前为止,我尝试过:
- 尝试查看具有问题的文件来自sdk源(API级别16和21),但它们与堆栈跟踪不相关(堆栈跟踪中显示的行指向一个不合理的位置)。 - 尝试安装XPosed修复Google PlayStore崩溃的菜单按钮错误。这里也没有找到解决方法。 - 在firefox的bugtracking系统中找到了一个类似的错误报告,因此我尝试安装Firefox并查看当我按Menu按钮时它是否会在我的手机上崩溃; firefox并没有崩溃。(Link to firefox's bug)
以下是LogCat中的堆栈跟踪:
10-24 09:08:02.710 4712-4712/com.scaryboxstudios.unrealestateapp E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.NullPointerException
at com.android.internal.policy.impl.PhoneWindow.onKeyUpPanel(PhoneWindow.java:1004)
at com.android.internal.policy.impl.PhoneWindow.onKeyUp(PhoneWindow.java:1712)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:2125)
at android.view.ViewRootImpl.deliverKeyEventPostIme(ViewRootImpl.java:3611)
at android.view.ViewRootImpl.handleImeFinishedEvent(ViewRootImpl.java:3581)
at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2831)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4929)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:798)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:565)
at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
at dalvik.system.NativeStart.main(Native Method)