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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Почему такой маленький heap ? 
:(
    Опции темы
zels
Дата 26.2.2011, 09:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Запускаю задачу для работы с большими массивами (~30млн объектов)
Памяти хватает только на создание 8млн.
Максимальный heap -Xmx1110m, больше не может выделить.
Установлено 4гб ОЗУ и WindowsXP.

JVM последняя (1.6_24) от Oracle.

Мне кажется, раньше была JVM, которая использовала 2Gb ОЗУ, но я не помню, что за версия.


P.S для справки: на C# программа использовала 1700Мб и создала 28млн объектов.
 



PM MAIL   Вверх
XoJIoD
Дата 26.2.2011, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Для 64 разрядной java можно выделить больше памяти.
PM MAIL   Вверх
tonklor
Дата 26.2.2011, 13:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Была аналогичная проблема. Вечерком распишу метод "лечения".
PM MAIL   Вверх
zels
Дата 26.2.2011, 14:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(XoJIoD @ 26.2.2011,  12:01)
Для 64 разрядной java можно выделить больше памяти.

Установил 64-разрядную Java (в Windows 7), чтобы попробовать...

Ключ Xmx3500m позволил дойти до 20млн, причем после 15млн очень сильные тормоза.


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


Эксперт
***


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

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



Завтра вам понадобится 60 млн. Перспективней искать другое архитектурное решение, т.е. разбить данные на порции и обрабатывать параллельно на разных JVM. В grid'е. 
PM MAIL   Вверх
zels
Дата 26.2.2011, 18:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



На части я разбил, мне хватит.

Непонятно, почему Java ест памяти намного больше, чем C#, ведь хранимая информация одинакова.

Не хочу спорить Java vs C#, просто в данном случае C# оказался предпочтительнее.




Это сообщение отредактировал(а) zels - 26.2.2011, 18:41
PM MAIL   Вверх
Skipy
Дата 28.2.2011, 12:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 487
Регистрация: 24.8.2006
Где: Москва, Россия

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



Пока Вы не привели код, невозможно сказать, что там не так. Ваши слова позволил дойти до 20млн, причем после 15млн очень сильные тормоза несколько не согласуются с принципами работы с массивами, где память выделяется единовременно и ее объем не меняется.


--------------------
С уважением,
Евгений aka Skipy
www.skipy.ru
PM MAIL WWW ICQ   Вверх
Temdegon
Дата 28.2.2011, 16:34 (ссылка) |  (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата

Ваши слова позволил дойти до 20млн, причем после 15млн очень сильные тормоза несколько не согласуются с принципами работы с массивами, где память выделяется единовременно и ее объем не меняется. 

Почему это? выделяется массив под 20млн ссылок на объекты, единовременно. Но основной объем памяти будет тратиться именно на сами экземпляры классов, которые потом будут создаваться и укладываться в этот массив. Вроде все логично.
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.1045 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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