Android应用_异常问题_AbsListView.onTouchEvent 空指针

自定义了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;
    }




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值