Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 18.02.2013
Сообщений: 51

ViewPager и многопоточность

12.11.2021, 09:57. Показов 730. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть активити в которой я отображаю вопросы(в количестве 30) через ViewPager. У меня есть методы для генерации вопросов. Я генерирую вопросы рандомно потом вставляю их в ViewPager, делаю я все это в onCreate() самой Activity.
Также у меня есть таймер 30 минут на тест и вот когда я запускаю активити таймер уже показывает что осталось 29.57, тоесть активити грузилась 3 секунды, это на холодном запуске, повторно это занимает 2 секунды.
Проблема - я получаю ANR Input dispatching timed out.
Java
1
2
3
4
@Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
    questions1 = generatorQuestions1.generate();            
    questions2 = generatorQuestions2.generate();
Я решил генерировать вопросы в потоках, я выделил 2 потока на каждый список.
Но он начал ругаться что метод getCount() адаптера получает пустую ссылку. Я проинициализировал списки пустотой.
Теперь код работает, но время выполнения то же самое.
Время загрузки активити не изменилось, но ANR хоть пропадет? Ведь я теперь не нагружаю UI поток генерацией вопросов, а делаю это в отдельных потоках.
Мне нужно эти потоки теперь как-то закрыть?
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
new Handler(getMainLooper()).post(new Runnable() {
@Override
public void run() {
    questions1 = generatorQuestions1.generate();
    pager.getAdapter().notifyDataSetChanged();
}
});
 
new Handler(getMainLooper()).post(new Runnable() {
@Override
public void run() {
    questions2 = generatorQuestions2.generate();
    pager.getAdapter().notifyDataSetChanged();
}
});
Добавлено через 10 минут
Также я взял старый код где генерировал вопросы в UI потоке и вставил туда логирование, чтоб увидеть за сколько генерируются вопросы.
2021-11-12 08:55:50.706 /TAG: НАЧАЛО
2021-11-12 08:55:50.790 /TAG: КОНЕЦ

То есть активити долго грузится совсем не из за генерации вопросов?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.11.2021, 09:57
Ответы с готовыми решениями:

ViewPager
Всем. Да я недалекий и тупой, уже дня три не могу никак понять :wall: Есть ViewPager <android.support.v4.view.ViewPager ...

ViewPager
Помогите пожалуйста. Использую эту фичу в своей программе(пример один и его очень много в поисковике). И столкнулся с проблемой. На...

ViewPager
Здравствуйте! В приложении использовал пример с Хабра http://habrahabr.ru/post/131889/, однако, не могу понять как при прокрутке экранов...

2
49 / 37 / 14
Регистрация: 05.02.2010
Сообщений: 249
12.11.2021, 10:26
Да, кроме генерации вопросов там еще очень многое происходит с точки зрения самой системы.
Можно попробовать запускать таймер в OnResume() активити. Это событие происходит в тот момент, когда активити уже становится доступна пользователю, т.е. полностью отрисовалась, определены все методы, установлены колбэки и т.д.

Еще неплохим UX решением может быть кнопка "Начать", которая запускает таймер...
0
1 / 1 / 0
Регистрация: 18.02.2013
Сообщений: 51
12.11.2021, 11:32  [ТС]
Я решил отследить программно время между вызовами onCreate() и onWindowFocusChanged().
2021-11-12 09:08:39.190/TAG: ONCREATE
2021-11-12 09:08:39.369/TAG: ONRESUME
2021-11-12 09:08:41.301/TAG: onWindowFocusChanged

Почему так долго отрисовывается активити?

Добавлено через 4 минуты
То что время стартует не с 30минут для меня это не столь проблематично. А вот то что ANR в некоторых случаях вылетает, вот это проблема. Ведь я ничего сложного не делаю , сгенерировал 30 вопросов и отдал их ViewPager. Вот мой алгоритм действий:
1)Генерирую вопросы
2)Инициализирую таймер
3)Создаю ViewPager
Все. Еще когда ViewPager инициализирует фрагменты он вешает колбеки. У меня активити общается с фрагментами из ViewPager.

Добавлено через 18 минут
Я заметил что при первом запуске уходит 1секунда на создание фрагментов для ViewPager после чего система тратит еще 1сек неизвестно на что.

Добавлено через 2 минуты
А вот еще, у меня есть кнопка НАЧАТЬ которая запускает эту активити. И вот из за того что она долго грузится можно успеть нажать второй раз на эту кнопку и создастся 2 активити.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2021, 11:32
Помогаю со студенческими работами здесь

ViewPager Indicator
Здравствуйте! Взял пример с https://github.com/JakeWharton/Android-ViewPagerIndicator и хотел бы объединить табы с индикатором который...

ViewPager автодаводка
Подскажите пожалст ,как можно изменить автодаводку уменьшить или увеличить?

Динамический ViewPager
Помогите создать динамический ViewPager http://stackoverflow.com/questions/13664155/dynamically-add-and-remove-view-to-viewpager ...

ViewPager и TextView
В приложении ViewPager и TextView. Все работает. Теперь нужно впихнуть во ViewPager 2 TextView. Можно ли это сделать и как?

создание ViewPager
здравствуйте,возник вопрос по ViewPager. Не получается добавить компоненты после ViewPager, т.е Статический компонент вверху и внизу,а по...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru