【问题标题】:Android Nullpointer Exception onQueryTextChange when switch fragment切换片段时Android Nullpointer Exception onQueryTextChange
【发布时间】:2014-10-18 10:22:59
【问题描述】:

我有以下问题:

当我从 fragment1 切换到 fragment2 时,我得到一个空指针异常。
fragment2 有一个带有过滤器的搜索视图。部分手机出现错误,不知道是什么原因。

应用在 mListAdapter.getFilter().filter 中崩溃:

        @Override
public boolean onQueryTextChange(String newText) {
    mListAdapter.getFilter().filter(newText);
    lv.setAdapter(mListAdapter);

    return false;
}

这里是 Logcat:

08-25 09:18:25.840: E/AndroidRuntime(1430): FATAL EXCEPTION: main
08-25 09:18:25.840: E/AndroidRuntime(1430): java.lang.NullPointerException
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.kansosystem.fragments.FragmentList.onQueryTextChange(FragmentList.java:291)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.SearchView.onTextChanged(SearchView.java:1154)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.SearchView.access$2000(SearchView.java:92)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.SearchView$11.onTextChanged(SearchView.java:1623)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.TextView.sendOnTextChanged(TextView.java:7079)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.TextView.setText(TextView.java:3550)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.TextView.setText(TextView.java:3405)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.EditText.setText(EditText.java:80)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.TextView.setText(TextView.java:3380)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.widget.TextView.onRestoreInstanceState(TextView.java:3280)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.View.dispatchRestoreInstanceState(View.java:11910)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:2590)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:2590)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:2590)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:2590)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.view.View.restoreHierarchyState(View.java:11888)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.android.internal.view.menu.MenuBuilder.restoreActionViewStates(MenuBuilder.java:358)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.android.internal.policy.impl.PhoneWindow.preparePanel(PhoneWindow.java:417)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.android.internal.policy.impl.PhoneWindow.invalidatePanelMenu(PhoneWindow.java:747)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.Activity.invalidateOptionsMenu(Activity.java:2595)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.FragmentManagerImpl.invalidateOptionsMenu(FragmentManager.java:1950)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.Fragment.setHasOptionsMenu(Fragment.java:901)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.kansosystem.fragments.FragmentList.onCreate(FragmentList.java:53)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:796)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1035)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.BackStackRecord.run(BackStackRecord.java:635)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1397)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.FragmentManagerImpl$1.run(FragmentManager.java:426)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.os.Handler.handleCallback(Handler.java:615)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.os.Handler.dispatchMessage(Handler.java:92)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.os.Looper.loop(Looper.java:137)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at android.app.ActivityThread.main(ActivityThread.java:4745)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at java.lang.reflect.Method.invokeNative(Native Method)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at java.lang.reflect.Method.invoke(Method.java:511)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
08-25 09:18:25.840: E/AndroidRuntime(1430):     at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • mListAdaptergetFilter() 返回 null
  • 如果列表适配器引用来自其他活动,您很可能在使用它时会得到 null。如果您的 mListAdapter 不为 null,则文档后面的 getFilter() 不应返回 null。
  • 我不认为它是 mListAdapter。 OnCreateView 有一个检查,如果适配器存在,当它不存在时,它创建一个。
  • 嗯,没有比 mListAdapter 更多的代码会导致空指针异常。如果第 291 行是“mListAdapter.getFilter().filter(newText);”您可以确定这是 mListAdapter 的问题。
  • 好的,我检查了适配器是否为空并且它为空。很奇怪,我检查代码并稍后写回,如果它有效。谢谢

标签: java android nullpointerexception searchview


【解决方案1】:

首先,确保您的适配器不是null。你可以简单地通过像

这样的日志来做到这一点
Log.d("tag","mListAdapter="+mListAdapter);
mListAdapter.getFilter().filter(newText);

然后检查 logcat 以查看 mListAdapter 是否提供 mListAdapter=null。如果是这样,那么问题出在您的适配器上。

其次,转到自定义列表适配器类中的getfilter 方法,并确保您的过滤器不返回null。它必须返回您的过滤器。

【讨论】:

    猜你喜欢
    • 2021-02-11
    • 1970-01-01
    • 2014-06-25
    • 1970-01-01
    • 2023-03-30
    • 1970-01-01
    • 2021-08-26
    • 2021-05-20
    • 1970-01-01
    相关资源
    最近更新 更多