Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Программа зависает, в случайный момент 
V
    Опции темы
yuliada
Дата 28.10.2009, 00:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Есть программа, которая иногда отрабатывает нормально до самого конца, но иногда почему-то вешается в совершенно случайный момент времени, при этом не реагирует ни на ctrl+c, ни на ctrl+break. jsatck тоже не работает (читала что есть опция -F, но я ее не могу использовать, т.к. под Windows). Пробовала коннектиться к зависшему процессу с помощью Java Visual VM - тоже не работает (говорит Connecting...).

Так же пробовала запустить программу, подцепиться к ней при помощи Java Visual VM с самого начала и посмотреть что будет в Threads visualization в момент зависания. Программа померла через 50 минут, вся информация о потоках была доступна только для этого периода времени, но при этом Java Visual VM и дальше была подцеплена к процессу (т.е. например timeline остановилось на отметке 49:23 и больше не менялось). Попробовала нажать на Thread dump - сработало, но в дампе ничего "криминального" не обнаружилось (может быть это не актуальный thread dump, а то, что Java Visual VM удалось получить до того как процесс повиснет?).

Что еще можно сделать чтоб найти ошибку и заставить программу стабильно работать?

Использется JDK1.6.0_16 (64-бит), Windows Vista Enterprise SP1 (64-бит).

Заранее спасибо.
PM MAIL   Вверх
mgarin
Дата 28.10.2009, 05:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 128
Регистрация: 19.8.2009
Где: Санкт-Петербург

Репутация: 1
Всего: 3



Ну, в случайный момент... - это на самом деле напоминает запирание swing-потока...

Когда у вас ведется достаточно много обновлений интерфейса извне Swing-потока,
это может приводить к подобному полному зависанию приложения в каком-то месте.
Причем такое зависание может возникнуть при разных обстоятельствах и будет зависеть от скорости машины,
на которой работает приложение, среды и др. факторов

Хотя, конечно, не увидев кода приложения, хотя бы части, сложно сказать.
Это только мои догадки smile
PM MAIL WWW ICQ   Вверх
yuliada
Дата 28.10.2009, 05:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Цитата

Ну, в случайный момент... - это на самом деле напоминает запирание swing-потока...

Когда у вас ведется достаточно много обновлений интерфейса извне Swing-потока,
это может приводить к подобному полному зависанию приложения в каком-то месте.
Причем такое зависание может возникнуть при разных обстоятельствах и будет зависеть от скорости машины,
на которой работает приложение, среды и др. факторов


На счет частых обновлений интерфейса - там есть progress bar и label, которые обновляются SwingWorker'ом через publish() и setProgress(), больше ничего не обновляется. Частоту обновлений не знаю как оценить... в общем там должно показаться где-то штук 55000 разных строк за час.

Цитата

Хотя, конечно, не увидев кода приложения, хотя бы части, сложно сказать.
Это только мои догадки smile 

Там много кода, не знаю в каком именно куске проблема, поэтому не знаю что можно запостить. Могу показать thread dump который удалось получить из Java Visual VM (в приложении).

Это сообщение отредактировал(а) yuliada - 28.10.2009, 05:54
PM MAIL   Вверх
yuliada
Дата 11.11.2009, 06:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Собрала на JDK 1.5 вместо 1.6. Программа уже 2 недели используется, пока не зависла ни разу.
...тьфу, тьфу, тьфу... smile
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1011 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.