RecyclerView滑动出现空指针异常
2016-05-07 14:42
302 查看
<span style="font-size:24px;"><strong>异常信息:</strong></span>
05-07 14:29:49.924: E/MessageQueue-JNI(16160): java.lang.NullPointerException 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v7.widget.RecyclerView.computeVerticalScrollOffset(RecyclerView.java:1613) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.View.canScrollVertically(View.java:11380) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v4.view.ViewCompatICS.canScrollVertically(ViewCompatICS.java:35) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v4.view.ViewCompat$ICSViewCompatImpl.canScrollVertically(ViewCompat.java:1253) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v4.view.ViewCompat.canScrollVertically(ViewCompat.java:1695) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v4.widget.SwipeRefreshLayout.canChildScrollUp(SwipeRefreshLayout.java:646) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v4.widget.SwipeRefreshLayout.onInterceptTouchEvent(SwipeRefreshLayout.java:660) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1827) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1968) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1420) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.app.Activity.dispatchTouchEvent(Activity.java:2428) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:60) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:60) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1916) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.View.dispatchPointerEvent(View.java:7437) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3610) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3538) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4790) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4750) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4902) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:179) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.os.MessageQueue.nativePollOnce(Native Method) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.os.MessageQueue.next(MessageQueue.java:125) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.os.Looper.loop(Looper.java:140) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at android.app.ActivityThread.main(ActivityThread.java:5297) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at java.lang.reflect.Method.invokeNative(Native Method) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at java.lang.reflect.Method.invoke(Method.java:511) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 05-07 14:29:49.924: E/MessageQueue-JNI(16160): at dalvik.system.NativeStart.main(Native Method) 05-07 14:29:49.930: E/AndroidRuntime(16160): FATAL EXCEPTION: main 05-07 14:29:49.930: E/AndroidRuntime(16160): java.lang.NullPointerException 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v7.widget.RecyclerView.computeVerticalScrollOffset(RecyclerView.java:1613) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.View.canScrollVertically(View.java:11380) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v4.view.ViewCompatICS.canScrollVertically(ViewCompatICS.java:35) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v4.view.ViewCompat$ICSViewCompatImpl.canScrollVertically(ViewCompat.java:1253) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v4.view.ViewCompat.canScrollVertically(ViewCompat.java:1695) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v4.widget.SwipeRefreshLayout.canChildScrollUp(SwipeRefreshLayout.java:646) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v4.widget.SwipeRefreshLayout.onInterceptTouchEvent(SwipeRefreshLayout.java:660) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1827) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2241) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1904) 05-07 14:29:49.930: E/AndroidRuntime(16160): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1968) 05-07 14:29:49.930: E/AndroidRuntime(16160): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1420) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.app.Activity.dispatchTouchEvent(Activity.java:2428) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:60) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:60) 05-07 14:29:49.930: E/AndroidRuntime(16160): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1916) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.View.dispatchPointerEvent(View.java:7437) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3610) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3538) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4790) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4750) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4902) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:179) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.os.MessageQueue.nativePollOnce(Native Method) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.os.MessageQueue.next(MessageQueue.java:125) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.os.Looper.loop(Looper.java:140) 05-07 14:29:49.930: E/AndroidRuntime(16160): at android.app.ActivityThread.main(ActivityThread.java:5297) 05-07 14:29:49.930: E/AndroidRuntime(16160): at java.lang.reflect.Method.invokeNative(Native Method) 05-07 14:29:49.930: E/AndroidRuntime(16160): at java.lang.reflect.Method.invoke(Method.java:511) 05-07 14:29:49.930: E/AndroidRuntime(16160): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833) 05-07 14:29:49.930: E/AndroidRuntime(16160): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 05-07 14:29:49.930: E/AndroidRuntime(16160): at dalvik.system.NativeStart.main(Native Method) 05-07 14:29:50.048: E/AppErrorDialog(2309): Failed to get ILowStorageHandle instance 05-07 14:29:50.305: E/AEE/DUMPSTATE(16293): copy_process: execv /system/xbin/showmap failed(2), No such file or directory 05-07 14:29:50.867: E/AEE/DUMPSTATE(16291): copy_file: Copy /proc/gpulog to SYS_GPU_INFO failed(2), No such file or directory 05-07 14:29:52.425: E/AEE/DUMPSTATE(16303): copy_process: execv /system/xbin/procrank failed(2), No such file or directory 05-07 14:29:53.023: E/AEE/DUMPSTATE(16291): copy_file: Copy /proc/slabinfo to SYS_SLAB_INFO failed(2), No such file or directory 05-07 14:29:53.113: E/AEE/DUMPSTATE(16291): copy_file: Copy /sys/kernel/debug/wakeup_sources to SYS_KERNEL_WAKELOCKS failed(2), No such file or directory
CourseActivity.java
private void initView() { 。。。 recyclerView = (RecyclerView) findViewById(R.id.rv_activity_course); 。。。 presenter.initCoursesList(); } @Override public void initCoursesList(List<Course> courses) { adapter = new CommonRecyclerViewAdapter<Course>(this, R.layout.item_activity_course, courses) { @Override public void convert(CommondRecyclerViewHolder holder, Course course) { //... } }; recyclerView.setLayoutManager(new LinearLayoutManager(this)); //关键点 recyclerView.setHasFixedSize(true); recyclerView.setAdapter(adapter); }
错误的关键在于:reclerView在初始化数据时由于执行的是耗时操作,而布局管理器又是在耗时操作的后面,导致在数据加载的过程中,还没设置布局管理器,此时就滑动reclerView就会报空指针的错误啦。
解决的方法也很简单,在findViewById之后马上就设置布局管理器就可以啦,即:
recyclerView = (RecyclerView) findViewById(R.id.rv_activity_course);
recyclerView.setLayoutManager(new LinearLayoutManager(this)); //关键点
//。。。。。。再做其他事情
相关文章推荐
- 344. Reverse String [easy] (Python)
- “农田灌溉(Farm Irrigation), ZOJ2412”问题的一种解法
- strchr 、 strrchr 、strrstr的实现
- [置顶] 写给立志做码农的大学生
- 向良好进军!
- 理解static关键字
- 写给立志做码农的大学生
- tabhost相关报错
- Android——小谈Android 6.0(棉花糖)
- 拾遗:Go 代码结构
- 移动办公应用——客户端架构
- leetcode 342 Power of four
- Windows 10 或将迎来自己的 Hand-off
- 第1章基础知识 (1)
- Visual Tracker Benchmark配置使用自己算法教程
- 垂直居中
- 怎么解决tomcat占用8080端口问题图文教程
- 移动前端开发:待处理
- Android 中Canvas的save(),saveLayer()和restore()解析
- Maven 常用仓库网址