103 / 69 / 19
Регистрация: 07.07.2014
Сообщений: 240
|
||||||||||||||||
1 | ||||||||||||||||
Модификатор synchronized и Runnable24.01.2016, 22:50. Показов 721. Ответов 3
Метки нет (Все метки)
Имеется сервис в котором крутится поток работающий с сетью, проблема в том, что при некоторых(больше месяца пытаюсь понять каких) обстоятельствах создается несколько экземпляров этого сервиса.
Перед запуском проверяю не запущен ли он так:
Не придумав ничего лучше решил сделать так:
Использование IntentService не подойдет, т.к. сервис должен стартовать в основном потоке. Как можно гарантировать запуск только 1 экземпляра сервиса? Что-то у меня совсем не выходит( Добавлено через 12 минут Пример лога от проблемного устройства
Добавлено через 56 минут Теоретически дубликат сервиса может запуститься таким образом: поскольку за жизнью сервиса следит AlarmManager может произойти так, что android грохнет сервис из-за внешних факторов, сработает AlarmManager и запустит его, затем android решит воскресить старый сервис (он же липкий START_STICKY) и вот уже 2 сервиса. Возможно на загруженном кучей приложений устройстве это происходит достаточно часто. Тогда задача сводится к следующему, как сделать так чтобы работал только 1 поток, попробую сделать из него singleton...
0
|
24.01.2016, 22:50 | |
Ответы с готовыми решениями:
3
Когда использовать модификатор для перемнной Volatile, а когда synchronized? Implements Runnable Не срабатывет пример с Runnable Ant i runnable jar file |
103 / 69 / 19
Регистрация: 07.07.2014
Сообщений: 240
|
|||||||||||||||||||||
25.01.2016, 12:55 [ТС] | 3 | ||||||||||||||||||||
Так лучше?
Печаль вся в том, что класс этого потока у меня в отдельном dex лежит и довольно часто в фоне обновляется. Если dex файл перегрузить новый класс этого потока напрочь забудет о синхронизации и о том что его устаревшая копия уже работает он не узнает. Добавлено через 1 час 36 минут В итоге сделал вот так:
Добавлено через 3 минуты Конечно если их не запускать одновременно, но в моем случае это невозможно
0
|
25.01.2016, 12:55 | 4 |
DarkVortex, да запустите Вы их через singleThreadPoolExecutor и всё
1
|
25.01.2016, 12:55 | |
25.01.2016, 12:55 | |
Помогаю со студенческими работами здесь
4
Внести переменную в поток runnable Не открывается Runnable JAR File Ошибки при добавлении new Runnable Обновление времени через Runnable synchronized Synchronized Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |