按菜单按钮时应用程序崩溃

The*_*ter 9 crash android

我正在尝试为Android创建一个应用程序,我遇到了以下问题:

当我按下菜单按钮时,应用程序在特定手机中崩溃.我先告诉你一些细节.

  • 只有使用Android 4.1.2的LG Optimus L3 II e430才会出现此错误(到目前为止已在其他四款手机上测试过)
  • 应用程序以启动屏幕开始,没有操作栏.此时菜单按钮不起作用.
  • 通过简单的触摸,我们可以通过启动画面,然后转到实现ActionBar活动的主活动,并有一个导航抽屉.
  • 从这一点开始,每次我尝试单击菜单按钮时,应用程序崩溃.

这是菜单的布局和onCreateOptionsMenu函数:

RES /菜单/ 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>
Run Code Online (Sandbox Code Playgroud)

部分来自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);
    }
Run Code Online (Sandbox Code Playgroud)

请注意,此代码是从Android Studio生成的.

到目前为止,我尝试过:

  • 试图从sdk源(API级别16和21)查看存在问题的文件,但它们与堆栈跟踪无关(在没有意义的位置指向的堆栈跟踪中显示的行).
  • 尝试使用菜单按钮错误安装XPosed fix for Google PlayStore崩溃.这里也没什么.
  • 发现一个类似的错误报告给firefox的bugtracking系统,所以当我按下菜单按钮时,我试图安装Firefox并查看它是否在我的手机上崩溃; firefox没有崩溃.(链接到firefox的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)
Run Code Online (Sandbox Code Playgroud)

The*_*ter 0

最近偶然发现同样的问题后,我找到了问题的根源。问题是旧的和新的支持库之间的兼容性问题。看来我在代码中使用了折旧的东西和新的东西。

很抱歉我有点抽象,但这个问题已经有 4 个月了,我不记得错误的代码行到底是什么。如果内存正常,问题在于 Android Studio 自动生成的用于应用程序抽屉活动的方法。我使用了 Android Studio 中的抽屉应用程序项目模板,并且我也选择支持非常旧的 Android API,因此 Android Studio 选择了已弃用的 Android 支持库。

重点是,当我重构代码以仅使用非折旧技术时,我解决了问题。

如果您遇到类似的问题,我强烈建议您删除 Android Studio(我假设您使用 Android Studio 或 Eclipse)标记为已折旧的所有内容。