Android开发中遇到的一些难以解决的crash
1.
java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter positionViewHolder{3fb6f7d9 position=15 id=-1, oldPos=-1, pLpos:-1 no parent}
at android.support.v7.widget.RecyclerView$Recycler.validateViewHolderForOffsetPosition(Proguard:5297)
at android.support.v7.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(Proguard:5479)
at android.support.v7.widget.GapWorker.prefetchPositionWithDeadline(Proguard:282)
at android.support.v7.widget.GapWorker.flushTaskWithDeadline(Proguard:336)
at android.support.v7.widget.GapWorker.flushTasksWithDeadline(Proguard:349)
at android.support.v7.widget.GapWorker.prefetch(Proguard:356)
at android.support.v7.widget.GapWorker.run(Proguard:387)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:902)
初步分析:
感觉应该是LayoutManager的问题:
自定义一个LayoutManager
public class TXZLinearLayoutManager extends LinearLayoutManager {
public TXZLinearLayoutManager(Context context) {
super(context);
}
public TXZLinearLayoutManager(Context context, int orientation, boolean reverseLayout) {
super(context, orientation, reverseLayout);
}
public TXZLinearLayoutManager(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
}
@Override
public boolean supportsPredictiveItemAnimations() {
return false;
}
@Override
public void onLayoutChildren(RecyclerView.Recycler recycler, RecyclerView.State state) {
try {
super.onLayoutChildren(recycler, state);
} catch (Exception e) {
LogUtil.loge("error onLayoutChildren",e);
}
}
@Override
public int scrollHorizontallyBy(int dx, RecyclerView.Recycler recycler, RecyclerView.State state) {
try {
return super.scrollHorizontallyBy(dx, recycler, state);
} catch (Exception e) {
LogUtil.loge("error scrollHorizontallyBy",e);
}
return 0;
}
}
//然后调用即可
mLayoutManager = new TXZLinearLayoutManager(GlobalContext.get());
recycleView.setLayoutManager(mLayoutManager);
但是如此改后,还是会出现问题,原因可能是由于多线程导致修改了data,然后刷新Adapter的时候,出现了问题.
修改的方法:无非就是在改变data的位置处统一在主线程中,并且在notifyDatachange即可.
可能在:Fragment调用destoryview的时候,此时接收到了刷新的事件(采用观察者的模式),
2.
java.lang.IllegalArgumentException: View not attached to window manager
at android.view.WindowManagerGlobal.findViewLocked(WindowManagerGlobal.java:383)
at android.view.WindowManagerGlobal.removeView(WindowManagerGlobal.java:285)
at android.view.WindowManagerImpl.removeView(WindowManagerImpl.java:79)
at android.app.Dialog.dismissDialog(Dialog.java:323)
at android.app.Dialog.dismiss(Dialog.java:306)
at android.app.Dialog.cancel(Dialog.java:1108)
at android.app.Dialog.onTouchEvent(Dialog.java:621)
at android.app.Dialog.dispatchTouchEvent(Dialog.java:743)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1992)
at android.view.View.dispatchPointerEvent(View.java:7430)
at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3224)
at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3169)
at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4296)
at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4275)
at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4367)
at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:179)
at android.os.MessageQueue.nativePollOnce(Native Method)
at android.os.MessageQueue.next(MessageQueue.java:125)
at android.os.Looper.loop(Looper.java:125)
at android.app.ActivityThread.main(ActivityThread.java:5089)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:800)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:567)
at dalvik.system.NativeStart.main(Native Method)