Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
#1

RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos - Программирование Android

01.08.2015, 10:08. Просмотров 1689. Ответов 13
Метки нет (Все метки)

Добрый день! У меня есть RecyvlerView, который изумительно работает на всех устройствах, кроме Samsung. На Samsung я получаю java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter positionViewHolder когда я пытаюсь вернуться назад на фрагмент с recyclerView с другой активити. Это код адаптера:

https://yadi.sk/d/HCD-tA__iD5jm

а это ошибка:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter positionViewHolder{42319ed8 position=1 id=-1, oldPos=0, pLpos:0 scrap tmpDetached no parent}
at android.support.v7.widget.RecyclerView$Recycler.validateViewHolderForOffsetPosition(RecyclerView.java:4166)
at android.support.v7.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:4297)
at android.support.v7.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:4278)
 at android.support.v7.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:1947)
 at android.support.v7.widget.GridLayoutManager.layoutChunk(GridLayoutManager.java:434)
 at android.support.v7.widget.LinearLayoutManager.fill(LinearLayoutManager.java:1322)
 at android.support.v7.widget.LinearLayoutManager.onLayoutChildren(LinearLayoutManager.java:556)
at android.support.v7.widget.GridLayoutManager.onLayoutChildren(GridLayoutManager.java:171)
at android.support.v7.widget.RecyclerView.dispatchLayout(RecyclerView.java:2627)
at android.support.v7.widget.RecyclerView.onLayout(RecyclerView.java:2971)
at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.support.v4.widget.SwipeRefreshLayout.onLayout(SwipeRefreshLayout.java:562)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
 at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.support.v4.view.ViewPager.onLayout(ViewPager.java:1626)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1677)
 at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1531)
 at android.widget.LinearLayout.onLayout(LinearLayout.java:1440)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.support.v4.view.ViewPager.onLayout(ViewPager.java:1626)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1677)
 at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1531)
 at android.widget.LinearLayout.onLayout(LinearLayout.java:1440)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
 at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1677)
 at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1531)
 at android.widget.LinearLayout.onLayout(LinearLayout.java:1440)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
 at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
07-30 12:48:22.688    9590-9590/com.Filmgrail.android.debug W/System.err? at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1677)
 at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1531)
 at android.widget.LinearLayout.onLayout(LinearLayout.java:1440)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
 at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
 at android.view.View.layout(View.java:15746)
 at android.view.ViewGroup.layout(ViewGroup.java:4867)
 at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2356)
 at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2069)
 at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1254)
 at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6630)
 at android.view.Choreographer$CallbackRecord.run(Choreographer.java:803)
 at android.view.Choreographer.doCallbacks(Choreographer.java:603)
 at android.view.Choreographer.doFrame(Choreographer.java:573)
 at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:789)
 at android.os.Handler.handleCallback(Handler.java:733)
 at android.os.Handler.dispatchMessage(Handler.java:95)
 at android.os.Looper.loop(Looper.java:136)
 at android.app.ActivityThread.main(ActivityThread.java:5479)
 at java.lang.reflect.Method.invokeNative(Native Method)
 at java.lang.reflect.Method.invoke(Method.java:515)
 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
 at dalvik.system.NativeStart.main(Native Method)
Буду очень признателен за помощь! Могу даже оплатить подсказку, которая решит проблему. Очень нужно!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 11:27  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #2
И ни одного ответа...
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
03.08.2015, 11:34     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #3
Данные где хранятся, что в адаптер идут?
API какие на устройствах?
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 13:03  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #4
Данные запрашиваются из внешнего АПИ, затем передаются в адаптер при его создание посредством массива. АПИ 15
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
03.08.2015, 13:31     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #5
Видно же d=-1, но Samsung тут причем?
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 13:43  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #6
При том, что это случается только на Samsung устройствах. На всех остальных работает нормально. В первый раз все загружатся нормально, но стоит мне уйтис recyclerView и вернуться, как в дебаге я вижу, что длина массива объектов почему-то равна 1 и он запрашивает индекс 1.
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
03.08.2015, 13:56     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #7
Создайте эмулятор с Samsung и тестируйте. Если все нормально, значит производитель накосячил. Или прошивка кривая. Ну или руки.
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 14:05  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #8
Эмулятор - это другое. У меня есть два реальных устройства Samsung - и ни на одном не работает. А на эмуляторах и всем остальном не самсунг работает прекрасно.
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
03.08.2015, 14:14     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #9
Значит ищем третий посторонний Samsung и проверяем.
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 14:19  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #10
Это не ответ.
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
03.08.2015, 14:42     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #11
Тогда пишите в битву экстрасенсов.
Pablito
2452 / 1897 / 590
Регистрация: 12.05.2014
Сообщений: 6,698
Завершенные тесты: 1
03.08.2015, 14:44     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #12
я уверен на 95% что при возврате с другой активити в ту, где этот RecyclerAdapter, не делается notifyDataSetChanged()
Pirokar
4 / 4 / 0
Регистрация: 21.10.2012
Сообщений: 54
03.08.2015, 15:25  [ТС]     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #13
Я пробовал делать notifyDataSetChanged() руками, не помогло
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.08.2016, 21:40     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos
Еще ссылки по теме:
Android Ошибка java.lang.ClassCastException: com.organizer.ToDoItemDescr cannot be cast to java.util.Map
Android Java.lang.ClasscastException
Android java.lang.NoClassDefFoundError
Android Java.lang.OutOfMemoryError
Ошибка java.lang.NullPointerException Android

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
CoolMind
418 / 401 / 65
Регистрация: 06.10.2012
Сообщений: 1,727
24.08.2016, 21:40     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos #14
Pirokar, только что получил такую же ошибку на таком же устройстве при сходных обстоятельствах.
В моём случае я решил поудалять тормозные notifyDataSetChanged и заменить на что-то вроде notifyItemRangeInserted. Но я забыл одну вещь. После возвращения из другого фрагмента у меня обнулялся (adapter.clear()) список. И там я забыл сделать adapter.notifyItemRangeRemoved(0, size); После прочтения http://stackoverflow.com/questions/3...cy-detected-in всё встало на свои места.
Зачем прислал код адаптера, непонятно, если надо было присылать работу с добавлением-удалением туда коллекций.
Пишу на всякий случай, вдруг, кто ещё увидит.
Yandex
Объявления
24.08.2016, 21:40     RecyclerView и java.lang.IndexOutOfBoundsException: Inconsistency detected. Invalid view holder adapter pos
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru