StaggeredGridLayoutManager calculateCachedStart() IndexOutOfBoundsException
Привет, я получил сообщение об ошибке от Fabric в моих приложениях -> IndexOutOfBoundsException в StaggeredGridLayoutManager метод figureCachedStart()
В моих приложениях много используется StaggeredGridLayoutManager. Любая идея, чтобы исправить эту ошибку или проследить, какая из моих приложений вызывает это?
Использование компиляции "com.android.support:recyclerview-v7:25.2.0
Fatal Exception: java.lang.IndexOutOfBoundsException: Invalid index 0, size is 0
at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:260)
at java.util.ArrayList.get(ArrayList.java:313)
at android.support.v7.widget.StaggeredGridLayoutManager$Span.calculateCachedStart(StaggeredGridLayoutManager.java:2457)
at android.support.v7.widget.StaggeredGridLayoutManager$Span.getStartLine(StaggeredGridLayoutManager.java:2474)
at android.support.v7.widget.StaggeredGridLayoutManager.checkSpanForGap(StaggeredGridLayoutManager.java:410)
at android.support.v7.widget.StaggeredGridLayoutManager.hasGapsToFix(StaggeredGridLayoutManager.java:359)
at android.support.v7.widget.StaggeredGridLayoutManager.checkForGaps(StaggeredGridLayoutManager.java:284)
at android.support.v7.widget.StaggeredGridLayoutManager.onScrollStateChanged(StaggeredGridLayoutManager.java:319)
at android.support.v7.widget.RecyclerView.dispatchOnScrollStateChanged(RecyclerView.java:4596)
at android.support.v7.widget.RecyclerView.setScrollState(RecyclerView.java:1371)
at android.support.v7.widget.RecyclerView.cancelTouch(RecyclerView.java:2890)
at android.support.v7.widget.RecyclerView.onTouchEvent(RecyclerView.java:2868)
at android.view.View.dispatchTouchEvent(View.java:8593)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2493)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2157)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2495)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2495)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2530)
at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2171)
at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2545)
at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1818)
at android.app.Activity.dispatchTouchEvent(Activity.java:2860)
at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:71)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2483)
at android.view.View.dispatchPointerEvent(View.java:8799)
at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:4866)
at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:4681)
at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4146)
at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4205)
at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4165)
at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:4335)
at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4173)
at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:4392)
at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4146)
at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4205)
at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4165)
at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4173)
at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4146)
at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:6694)
at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:6668)
at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:6621)
at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:6853)
at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:216)
at android.view.InputEventReceiver.nativeConsumeBatchedInputEvents(InputEventReceiver.java)
at android.view.InputEventReceiver.consumeBatchedInputEvents(InputEventReceiver.java:192)
at android.view.ViewRootImpl.doConsumeBatchedInput(ViewRootImpl.java:6812)
at android.view.ViewRootImpl$ConsumeBatchedInputRunnable.run(ViewRootImpl.java:6879)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:804)
at android.view.Choreographer.doCallbacks(Choreographer.java:607)
at android.view.Choreographer.doFrame(Choreographer.java:574)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:790)
at android.os.Handler.handleCallback(Handler.java:815)
at android.os.Handler.dispatchMessage(Handler.java:104)
at android.os.Looper.loop(Looper.java:210)
at android.app.ActivityThread.main(ActivityThread.java:5833)
at java.lang.reflect.Method.invoke(Method.java)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1113)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:879)
Спасибо
3 ответа
Если твой RecyclerView
находится в Fragment
и ваш Fragment
в ViewPager
, а ты не поставил viewpager.setOffscreenPageLimit(MAX_ITEM_SIZE)
, эта авария иногда случится неожиданно.
Я терпел такие же аварии. Я не могу воспроизвести это, и не знаю, почему это произошло до сих пор. Но после того, как я установил лимит закадровых страниц, этот сбой проходит.
Жаль, что это помогает.
Это часть StaggeredGridLayoutManager.java
/**
* Checks for gaps in the UI that may be caused by adapter changes.
* <p>
* When a full span item is laid out in reverse direction, it sets a flag which we check when
* scroll is stopped (or re-layout happens) and re-layout after first valid item.
*/
boolean checkForGaps() {
if (getChildCount() == 0 || mGapStrategy == GAP_HANDLING_NONE || !isAttachedToWindow()) {
return false;
}
final int minPos, maxPos;
if (mShouldReverseLayout) {
minPos = getLastChildPosition();
maxPos = getFirstChildPosition();
....
В качестве обходного пути мы можем предотвратить
StaggeredGridLayoutmanager.hasGapsTofix()
вызов (что является причиной этого сбоя).
staggeredGridLayoutmanager.gapStrategy = StaggeredGridLayoutManager.GAP_HANDLING_NONE
Но эта опция отключает обработку неожиданных пробелов.
У меня была аналогичная проблема. В моем случае у меня был один "родительский" RecyclerView, и у одного из его элементов был собственный "дочерний" RecyclerView с StaggeredGridLayoutManager. Произошел сбой, когда ViewHolder, подключенный к этому элементу, был переработан. Настройка RecyclerView.ViewHolder.setIsRecyclable(false) на этом ViewHolder устранила проблему для меня