【发布时间】:2018-12-04 17:31:43
【问题描述】:
在继续之前,我在谷歌上搜索了这个错误,我发现了很多可用的答案,但我的情况与他们的情况不同。
java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid item position 2(offset:2).state:3
我正在使用 recyclerview 显示投票问题,每个问题都有一个计时器,当计时器用完时,项目将从列表中删除。
当计时器用完时会发生异常,但仅在极少数情况下剩余时间较少(例如 100 毫秒)。所以在这种情况下,可能是 recyclerview 正在膨胀项目,同时,计时器用完并且 recyclerview 尝试删除该项目。
错误是当计时器删除项目时我得到异常。
因此,当该轮询剩余 1 秒或更少秒时,我从数据集中删除元素后解决了这个问题。所以它不会在列表中添加项目,而是会运行计时器。
如果您想产生错误,只需启动倒数计时器
bindView并且一旦计时器用完,就删除该特定项目。 您必须使计时器低于 500 毫秒。
所以现在一切正常。解决了罕见情况下的崩溃问题,但即使剩余时间较少,我也不想从数据集中删除该元素。请给我这个错误的正确解决方案。
已编辑
java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid item position 1(offset:1).state:2 com.lsjwzh.widget.recyclerviewpager.RecyclerViewPager{182da0c VFED..... .F....ID 0,0-720,1024 #7f0a01a1 app:id/recycler_view}, adapter:com.lsjwzh.widget.recyclerviewpager.RecyclerViewPagerAdapter@c9403f, layout:android.support.v7.widget.LinearLayoutManager@6fdbd0c, context:com.bitpoll.polls.MainActivity@b40f4c0
android.support.v7.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:5817)
android.support.v7.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:5752)
android.support.v7.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:5748)
android.support.v7.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:2232)
android.support.v7.widget.LinearLayoutManager.layoutChunk(LinearLayoutManager.java:1559)
android.support.v7.widget.LinearLayoutManager.fill(LinearLayoutManager.java:1519)
android.support.v7.widget.LinearLayoutManager.onLayoutChildren(LinearLayoutManager.java:614)
android.support.v7.widget.RecyclerView.dispatchLayoutStep2(RecyclerView.java:3812)
android.support.v7.widget.RecyclerView.dispatchLayout(RecyclerView.java:3529)
android.support.v7.widget.RecyclerView.onLayout(RecyclerView.java:4082)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.support.v4.widget.SwipeRefreshLayout.onLayout(SwipeRefreshLayout.java:606)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.RelativeLayout.onLayout(RelativeLayout.java:1189)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.support.constraint.ConstraintLayout.onLayout(ConstraintLayout.java:1855)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.support.design.widget.HeaderScrollingViewBehavior.layoutChild(HeaderScrollingViewBehavior.java:132)
android.support.design.widget.ViewOffsetBehavior.onLayoutChild(ViewOffsetBehavior.java:42)
android.support.design.widget.AppBarLayout$ScrollingViewBehavior.onLayoutChild(AppBarLayout.java:1361)
android.support.design.widget.CoordinatorLayout.onLayout(CoordinatorLayout.java:894)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.RelativeLayout.onLayout(RelativeLayout.java:1189)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.FrameLayout.layoutChildren(FrameLayout.java:383)
android.widget.FrameLayout.onLayout(FrameLayout.java:321)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.LinearLayout.setChildFrame(LinearLayout.java:1982)
android.widget.LinearLayout.layoutVertical(LinearLayout.java:1826)
android.widget.LinearLayout.onLayout(LinearLayout.java:1735)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.FrameLayout.layoutChildren(FrameLayout.java:383)
android.widget.FrameLayout.onLayout(FrameLayout.java:321)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.LinearLayout.setChildFrame(LinearLayout.java:1982)
android.widget.LinearLayout.layoutVertical(LinearLayout.java:1826)
android.widget.LinearLayout.onLayout(LinearLayout.java:1735)
android.view.View.layout(View.java:17969)
android.view.ViewGroup.layout(ViewGroup.java:5721)
android.widget.FrameLayout.layoutChildren(FrameLayout.java:383)
android.widget.FrameLayout.onLayout(FrameLayout.java:321)
com.android.internal.policy.DecorView.onLayout(DecorView.java:753)
android.view.View.layout(View.java:17969)
更新
这是适配器代码。
public class PollAdapter extends RecyclerView.Adapter<PollAdapter.PollViewHolder> {
// ....
@Override
public void onBindViewHolder(@NonNull PollViewHolder holder, int position) {
// ...
if (holder.countDownTimer != null) {
holder.countDownTimer.cancel();
}
// CountDown to set Timer in poll
holder.countDownTimer = new CountDownTimer(<Timer to be finished.>, 1000) {
public void onTick(long millisUntilFinished) {
holder.time.setText("<Remaining time>");
}
public void onFinish() {
removeAt(holder.getAdapterPosition());
}
}.start();
}
@Override
public int getItemCount() {
return pollList.size();
}
// To Remove Poll after Time finished
public void removeAt(int position) {
pollList.remove(position);
notifyItemRemoved(position);
}
}
【问题讨论】:
-
是否在非 UI 线程上进行任何操作?发布完整的堆栈跟踪可能会有所帮助。
-
@Cheticamp 添加了完整的堆栈跟踪。
-
你可以分享你的代码吗?
-
@RahulShukla 没有额外的代码。只需考虑普通的回收站视图适配器。额外的部分是我在
onBindView方法中启动计时器并通过调用notifyItemRemoved(pos)删除其上的元素onFinished方法。一切正常,除了,当我添加元素计时器低于 1 秒然后它崩溃了。 -
@Moinkhan,低于 1 秒的任何内容实际上对用户来说是不可见的。无论如何,您是否为 onBindView() 中的每个项目创建了新的计时器?
标签: java android listview android-recyclerview