java.lang.IndexOutOfBoundsException: Invalid index 2, size is 1

今天android程序发生了一个异常,查询日志后发现日志如下:

java.lang.IndexOutOfBoundsException: Invalid index 2, size is 1
at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:255)
at java.util.ArrayList.get(ArrayList.java:308)
at android.widget.HeaderViewListAdapter.getView(HeaderViewListAdapter.java:225)
at android.widget.AbsListView.obtainView(AbsListView.java:2440)
at android.widget.ListView.makeAndAddView(ListView.java:1876)
at android.widget.ListView.fillDown(ListView.java:702)
at android.widget.ListView.fillGap(ListView.java:666)
at android.widget.AbsListView.trackMotionScroll(AbsListView.java:5315)
at android.widget.AbsListView.scrollIfNeeded(AbsListView.java:3583)
at android.widget.AbsListView.onTouchMove(AbsListView.java:4002)
at android.widget.AbsListView.onTouchEvent(AbsListView.java:3817)
at android.view.View.dispatchTouchEvent(View.java:9332)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2576)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2257)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at com.scwang.smartrefresh.layout.SmartRefreshLayout.dispatchTouchEvent(SmartRefreshLayout.java:850)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2582)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2271)
at com.android.internal.policy.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2506)
at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1792)
at android.app.Activity.dispatchTouchEvent(Activity.java:2870)
at com.android.internal.policy.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2465)
at android.view.View.dispatchPointerEvent(View.java:9564)
at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:4331)
at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:4185)
at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3703)
at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3769)
at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3729)
at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:3868)
at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3737)
at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:3925)
at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3703)
at android.view.ViewRootImpl$InputStage.on

我把日志继续找出来,发现是在刷新的时候出错的。而且,当时出错的场景为网络条件下极差的环境。

于是,查询相关资料;查询的资料标识,是由于数据进行清除,但Adapter(界面展示)却进行了刷新,造成界面和实际数据不一致。

解决方法:及时更改数据和刷新数据。

笔者的解决方案:

设置数据和刷新数据在一个过程。

经测试,暂未发现问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值