Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Java: Общие вопросы > Ускорить процесс закрытия приложения


Автор: kkorsakoff 28.11.2007, 14:37
Насколько я понимаю, при закрытии приложения при помощи System.exit() или извне производятся следующие действия:

1. Запускаются все ShutdownHooks
2. Полный Garbage Collect
3. Процесс останавливается
4. ... что-то еще, что я не перечислил

Приложение останавливается очень медленно, т.к. на момент остановки используемая память может быть достаточно велика. Есть ли возможность ускорить остановку, пожертвовав, например, полным GC?
Или может есть возможность "убить" приложение изнутри?

Автор: AlexeyVorotnikov 28.11.2007, 14:54
Полный GC и не производится.

Можно попробовать убить JVM через Runtime.halt().

Автор: COVD 28.11.2007, 21:59
Приложение медленно закрывается, когда оно имеет открытые соединения с другими компьютерами - дб, сокеты. На закрытие их уходит время. А если никаких связей нет, то JVM умирает довольно быстро. Сталкиваюсь с  медленным закрытием у jnlp (WebStart) клиента. Компьютер просто замораживается на несколько секунд, ничего делать не возможно. В противоположность этому апплет, например, закрывался легко, но сервер частенько и не знал ничего об этом.

Автор: kkorsakoff 30.11.2007, 14:09
Тем не менее, у меня GC все-таки проходит. И делает она это от 2 до 5-8 секунд. Пытаюсь разобраться почему она отрабатывает. Я использую jniwrapper - враппер сишных функций. Возможно связано с ним, т.к. он подчищает нативные ресурсы.

Да, сокеты действительно есть. Но я всем потокам делаю interrupt и умирают они достаточно быстро.

Автор: COVD 30.11.2007, 19:17
Цитата

Да, сокеты действительно есть. Но я всем потокам делаю interrupt и умирают они достаточно быстро.


Главное закрыть свои соединения с внешними компьютерами, а не свои потоки. Это прежде всего забота о внешних компьютерах. Чтобы они были информированы о закрытии соединения и освободили соответствующие ресурсы. Если в приложении есть только открытые потоки, то достаточно System.exit - не обязательно каждый поток явно останавливать. Вроде так.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)