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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Необходимо уменьшить потребление памяти. Как избежать перерасхода памяти? 
:(
    Опции темы
isabsent
Дата 13.4.2012, 22:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Запускаю два раза подряд приложение с разными параметрами. Первый раз потребляется очень много памяти - порядка 1 ГБ - так и должно  быть, задача на большой перебор. Как видно на картинкеuser posted image - первый большой "зуб" - после того как приложение завершило работу, память освобождается. Запуск со вторым параметром потребляет совсем немного памяти - маленький "зуб" следом за большим. 

Теперь запускаю в коротком цикле эти же две операции - третий большой широкий зуб. Видно, что памяти потребляется больше чем в первом и счет продолжается дольше, чем если считать отдельные задачи. 

Вопрос - почему так нерационально используется память и что сделать, чтобы уйти от такого поведения? Задача тяжёлая для счета - приходится оптимизировать.

P.S. Все ненужные листы и ссылки на них при завершении каждой операции в цикле сначала почистил, потом объявил как null. Пробовал вызывать gc после первой опреации в цикле - стало только хуже.
PM MAIL   Вверх
dorogoyIV
Дата 13.4.2012, 23:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



Цитата(isabsent @  13.4.2012,  22:59 Найти цитируемый пост)
Все ненужные листы и ссылки на них при завершении каждой операции в цикле сначала почистил, потом объявил как null. Пробовал вызывать gc после первой опреации в цикле - стало только хуже.

еще убрать все static

Добавлено через 2 минуты и 24 секунды
неправильно сказал...
убрать ты их не сможешь, просто их не должно быть изначально
PM MAIL   Вверх
isabsent
Дата 13.4.2012, 23:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Я сам static'ом ничего не объявлял пока. Каким профайлером можно посмотреть что происходит с ненужными объектами, какие ссылки их удерживают от уничтожения когда я принудительно запускаю gc? В VisualVM я такой опции не нашёл... 

Это сообщение отредактировал(а) isabsent - 13.4.2012, 23:38
PM MAIL   Вверх
dorogoyIV
Дата 13.4.2012, 23:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



упс!!!
без VisualVM можешь загрузить прогу и посмотреть?

PM MAIL   Вверх
isabsent
Дата 14.4.2012, 00:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Экспериментальным путём выяснил, что если проявить настойчивость smile и сделать 
Код

                System.gc();
                System.gc();
                System.gc();
                System.gc();
 вместо одного вызова, который я делал раньше, то проблема решается. Но это как-то дико выглядит...
PM MAIL   Вверх
dorogoyIV
Дата 14.4.2012, 00:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



наверное твоя VisualVM в хеше хранит всю прогу, даже выключенную.
PM MAIL   Вверх
isabsent
Дата 14.4.2012, 00:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Нет, VisualVM я не запускал. Это я раньше пытался ею понять где те ссылки, которые не дают уничтожить объекты ненужные.
PM MAIL   Вверх
dorogoyIV
Дата 14.4.2012, 01:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



т.е. ты запустил прогу без IDE, и все равно память утекает? (как запускал?)
ну все равно, посмотри в диспетчер задач (если винда у тебя).

может быть цикл бесконечный запущен, или таймер с режимом меньше ну 500 например...

наверняка у тебя есть стандартная JVM. попробуй под ней скомпилировать и запустить эту прогу.

PM MAIL   Вверх
isabsent
Дата 14.4.2012, 08:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Нет, я ее запускал под IDE, но не под профайлером.
PM MAIL   Вверх
isabsent
Дата 14.4.2012, 09:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Если оставить один вызов gc после каждой операции в цикле (сделал одну "тяжёлую" по потреблению памяти операцию и 5 следующих за ней "лёгких" в цикле).
Так выглядит потребление памяти без IDE user posted image
А вот так под IDEuser posted image

Очевидно, что под IDE однкратный вызов gc не очищает ненужные объекты так же "хорошо" как если запускать jar-файл без IDE.


Это сообщение отредактировал(а) isabsent - 14.4.2012, 10:33
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.0813 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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