【问题标题】:Null pointer exception showing in action bar sherlock library操作栏 Sherlock 库中显示空指针异常
【发布时间】:2013-04-10 01:00:59
【问题描述】:

我想实现 Sherlock 操作栏的搜索视图小部件。我的问题是搜索视图项的OnOptionItemSelected。我在库活动中遇到空指针异常。

菜单xml:

<item android:id="@+id/menu_search"
      android:actionViewClass="com.actionbarsherlock.widget.SearchView"
      android:icon="@android:drawable/ic_menu_search"
/>

选项菜单的代码 sn-p:

public boolean onCreateOptionsMenu(Menu menu) 
{
    MenuInflater inflater = getSupportMenuInflater();
    inflater.inflate(R.menu.tvguide_menu, menu);
    MenuItem mSearch = menu.findItem(R.id.menu_search);
    searchView = new SearchView(getSupportActionBar().getThemedContext());
    searchView.setQueryHint("Search for countries…");
    searchView.setOnQueryTextListener(this);
    mSearch.setActionView(searchView);
    mSearch.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM |
            MenuItem.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW);
}

我在点击搜索 android 时被强制关闭。我在下面分享了我的日志

04-17 15:10:08.508: E/AndroidRuntime(23283): FATAL EXCEPTION: main
04-17 15:10:08.508: E/AndroidRuntime(23283): java.lang.NullPointerException
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.MenuItemImpl.toString(MenuItemImpl.java:490)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at java.lang.StringBuilder.append(StringBuilder.java:202)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.actionbarsherlock.app.SherlockFragmentActivity.onMenuItemSelected(SherlockFragmentActivity.java:201)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:953)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.ActionMenuView.invokeItem(ActionMenuView.java:491)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.view.menu.ActionMenuItemView.onClick(ActionMenuItemView.java:110)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.view.View.performClick(View.java:3511)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.view.View$PerformClick.run(View.java:14105)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.os.Handler.handleCallback(Handler.java:605)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.os.Handler.dispatchMessage(Handler.java:92)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.os.Looper.loop(Looper.java:137)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at android.app.ActivityThread.main(ActivityThread.java:4438)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at java.lang.reflect.Method.invokeNative(Native Method)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at java.lang.reflect.Method.invoke(Method.java:511)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
04-17 15:10:08.508: E/AndroidRuntime(23283):    at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • 请来自 logcat 的堆栈跟踪?
  • 我分享了请看一下。
  • 您添加的logcat错误不可见,请检查
  • 我觉得应该是searchView = (SearchView) mSearch.getActionView(),而不是new SearchView()
  • @DoctororDrive 我更改了代码,但仍然得到相同的日志猫 android

标签: android actionbarsherlock


【解决方案1】:

问题是您的Menu 项目没有指定标题,并且在该行中:

@Override
public final boolean onMenuItemSelected(int featureId, android.view.MenuItem item) {
    if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " 
           + featureId + ", item: " + item);
    ...
}

item 将使用toString() 方法:

@Override
public String toString() {
    return mTitle.toString();
}

将抛出一个NullPointerException。一个简单的解决方法是使用:

android:title=""

为您的MenuItem

此外,这不会在您的应用程序发布时发生。

【讨论】:

    【解决方案2】:

    是ActionBarSherlock 4.3.0版本的bug,我是这样修复的(需要注释actionbarsherlock/src/com/actionbarsherlock/app/SherlockFragmentActivity.java的201行:

    --- a/actionbarsherlock/src/com/actionbarsherlock/app/SherlockFragmentActivity.java
    +++ b/actionbarsherlock/src/com/actionbarsherlock/app/SherlockFragmentActivity.java
    @@ -198,7 +198,7 @@ public class SherlockFragmentActivity extends Watson implements OnActionModeStar
    
         @Override
         public final boolean onMenuItemSelected(int featureId, android.view.MenuItem item) {
    -        if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item);
    +       // if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item);
    
             if (featureId == Window.FEATURE_OPTIONS_PANEL && !mIgnoreNativeSelected) {
                 mIgnoreNativeSelected = true;
    

    【讨论】:

      【解决方案3】:

      如果有人遇到这个问题并且想要创建没有标题的菜单项,这个空指针异常可以通过简单地修改actionbarsherlock源代码中com/android/internal/view/menu/MenuItemImpl类中的toString()方法在返回前进行​​空字符串检查来解决:

      @Override
      public String toString() {
          return (mTitle != null)? mTitle.toString(): "";
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2016-02-03
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多