前言:我使用的构建库版本有点新29.0.3 ,我怀疑google这次升级重构过代码,之前的一些解决办法不行了,例如重写 LinearLayoutManager 的一些方法进行异常捕获。
此处跳转对这个问题讨论的比较集中,处理的方式也挺多的,我都试了不得行,大家可以看看 。
目录
2、(异常的抛出地方为) 6208 行 我们定位过去看一下。
3、我们通过开发工具 Ctrl + f 进行搜索 (有两处抛出该异常)
1、首先具体的异常如下。
java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid item position 5(offset:5).state:21 com.jykt.magic.view.LimitHVRecyclerView{9fa82b VFE...... ......ID 173,0-1695,868 #7f080198 app:id/list_items}, adapter:com.zhy.adapter.recyclerview.wrapper.HeaderAndFooterWrapper@579e488, layout:com.jykt.magic.adapter.base.WrapContentLinearLayoutManager@1b7ee21, context:com.jykt.magic.mall.MallShopGoodsCommentActivity@ea3a602
at androidx.recyclerview.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:6280)
at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:6216)
at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:6212)
at androidx.recyclerview.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:2314)
at androidx.recyclerview.widget.LinearLayoutManager.layoutChunk(LinearLayoutManager.java:1631)
at androidx.recyclerview.widget.LinearLayoutManager.fill(LinearLayoutManager.java:1591)
at androidx.recyclerview.widget.LinearLayoutManager.scrollBy(LinearLayoutManager.java:1395)
at androidx.recyclerview.widget.LinearLayoutManager.scrollVerticallyBy(LinearLayoutManager.java:1132)
at androidx.recyclerview.widget.RecyclerView.scrollStep(RecyclerView.java:1903)
at androidx.recyclerview.widget.RecyclerView$ViewFlinger.run(RecyclerView.java:5382)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1256)
at android.view.Choreographer.doCallbacks(Choreographer.java:995)
at android.view.Choreographer.doFrame(Choreographer.java:883)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1224)
at android.os.Handler.handleCallback(Handler.java:900)
at android.os.Handler.dispatchMessage(Handler.java:103)
at android.os.Looper.loop(Looper.java:219)
at android.app.ActivityThread.main(ActivityThread.java:8387)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:513)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1055)
2、(异常的抛出地方为) 6208 行 我们定位过去看一下。
3、我们通过开发工具 Ctrl + f 进行搜索 (有两处抛出该异常)
4、我发现相关的调用地方方法均不可重写。
所以通过复写方法捕获异常行不通了。
5、最终解决
我牺牲了一点性能,当界面发生刷新时,我选择重新实例Adapter,居然解决了这个问题 ^-^,反复测试确实解决了 。
希望能够帮助到你 。