自定义了ListView,at android.widget.AbsListView.onTouchEvent空指针,问题日志
07-30 20:31:22.984 E/InputEventReceiver(12362): Exception dispatching input event.
07-30 20:31:22.984 E/MessageQueue-JNI(12362): Exception in MessageQueue callback: handleReceiveCallback
07-30 20:31:23.004 E/MessageQueue-JNI(12362): java.lang.NullPointerException
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.widget.AbsListView.onTouchEvent(AbsListView.java:3588)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.taptech.common.widget.pull.XListView.onTouchEvent(XListView.java:382)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.View.dispatchTouchEvent(View.java:7216)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2277)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2012)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2011)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1461)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.app.Activity.dispatchTouchEvent(Activity.java:2452)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1959)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.View.dispatchPointerEvent(View.java:7396)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3235)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3180)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4216)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4195)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4287)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:171)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.os.MessageQueue.nativePollOnce(Native Method)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.os.MessageQueue.next(MessageQueue.java:125)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.os.Looper.loop(Looper.java:124)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at android.app.ActivityThread.main(ActivityThread.java:4875)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at java.lang.reflect.Method.invokeNative(Native Method)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at java.lang.reflect.Method.invoke(Method.java:511)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:804)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:571)
07-30 20:31:23.004 E/MessageQueue-JNI(12362): at dalvik.system.NativeStart.main(Native Method)
07-30 20:31:23.014 W/dalvikvm(12362): threadid=1: thread exiting with uncaught exception (group=0x41ae1498)
07-30 20:31:23.024 E/AndroidRuntime(12362): FATAL EXCEPTION: main
07-30 20:31:23.024 E/AndroidRuntime(12362): java.lang.NullPointerException
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.widget.AbsListView.onTouchEvent(AbsListView.java:3588)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.taptech.common.widget.pull.XListView.onTouchEvent(XListView.java:382)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.View.dispatchTouchEvent(View.java:7216)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2277)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2012)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2283)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1984)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2011)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1461)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.app.Activity.dispatchTouchEvent(Activity.java:2452)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1959)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.View.dispatchPointerEvent(View.java:7396)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3235)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3180)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4216)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4195)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4287)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:171)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.os.MessageQueue.nativePollOnce(Native Method)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.os.MessageQueue.next(MessageQueue.java:125)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.os.Looper.loop(Looper.java:124)
07-30 20:31:23.024 E/AndroidRuntime(12362): at android.app.ActivityThread.main(ActivityThread.java:4875)
07-30 20:31:23.024 E/AndroidRuntime(12362): at java.lang.reflect.Method.invokeNative(Native Method)
07-30 20:31:23.024 E/AndroidRuntime(12362): at java.lang.reflect.Method.invoke(Method.java:511)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:804)
07-30 20:31:23.024 E/AndroidRuntime(12362): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:571)
07-30 20:31:23.024 E/AndroidRuntime(12362): at dalvik.system.NativeStart.main(Native Method)
07-30 20:31:23.024 W/ActivityManager( 522): Force finishing activity com.taptech.wemedia/.activity.MoreTopicsActivity
07-30 20:31:23.054 V/PhoneStatusBar( 713): setLightsOn(true)
07-30 20:31:23.195 D/dalvikvm( 522): GC_CONCURRENT freed 5571K, 29% free 26835K/37319K, paused 15ms+13ms, total 105ms
07-30 20:31:23.195 D/dalvikvm( 522): WAIT_FOR_CONCURRENT_GC blocked 91ms
07-30 20:31:23.545 W/ActivityManager( 522): Activity pause timeout for ActivityRecord{42c0cb98 com.taptech.wemedia/.activity.MoreTopicsActivity}
看了半天,都没搞明白,通过不断调式分析,最后找到原因
getAdapter 未判空就返回,直接导致,ListView报空指针(最sb的犯错,mAdapter=(TTMoreTopicsAdapter) mAdapter),因此,传一个空的adapter也会带来同样的问题。
@Override
public void setAdapter(ListAdapter adapter) {
mAdapter = (TTMoreTopicsAdapter) mAdapter;
super.setAdapter(adapter);
}
@Override
public ListAdapter getAdapter() {
return mAdapter;
}
合理 做法
@Override
public void setAdapter(ListAdapter adapter) {
mAdapter = (TTMoreTopicsAdapter) mAdapter;
super.setAdapter(adapter);
}
@Override
public ListAdapter getAdapter() {
if (mAdapter == null) {
return super.getAdapter();
}
return mAdapter;
}