|
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
|
|||||||||||
Удалить все объекты у которых переменная равна false04.08.2016, 15:21. Показов 1386. Ответов 7
Метки нет (Все метки)
Добрый день, форумчане.
Вопрос связанный с памятью: Есть около 43000 объектов у которых есть переменная булева типа. С определенными целями мы бегаем по ArrayList из этих объектов. В конце концов нам надо будет удалить все объекты у которых эта переменная false. Как нам сделать это с наименьшими затратами памяти: Так:
UPD: Нашел ссылку на хабрастатью, где говориться про то, что нежелательно использовать много split()'ов: Типичные случаи утечки памяти в Java
0
|
|||||||||||
| 04.08.2016, 15:21 | |
|
Ответы с готовыми решениями:
7
Продолжение сканирования на Bitmap изображение, если переменная равна false
|
|
-28 / 35 / 25
Регистрация: 14.06.2013
Сообщений: 1,452
|
|
| 04.08.2016, 15:45 | |
|
0
|
|
|
206 / 206 / 71
Регистрация: 25.02.2014
Сообщений: 569
|
|
| 04.08.2016, 15:56 | |
|
0
|
|
|
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
|
|
| 04.08.2016, 17:40 [ТС] | |
|
RAFA91, немного не понял вопроса. В смысле "приводить"?
ne2win, да, просто ситуация в том, что в Java я очень сильный новичок и не знаю тонкостей, а приложение жрет память как подорванное, соответственно нужно освободить уже не использованную как можно быстрее. Не плавнее - черт с плавностью, а именно быстрее. Соответственно вопрос можно переформулировать, как "В каком из двух вариантов у нас к точке Х окажется больше памяти"? Точка Х в первом случае сразу после цикла, во втором - после окончания работы метода removeIf();
0
|
|
|
206 / 206 / 71
Регистрация: 25.02.2014
Сообщений: 569
|
|||
| 04.08.2016, 17:50 | |||
Сообщение было отмечено Zelmm как решение
Решение
1
|
|||
|
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
|
|||
| 05.08.2016, 09:27 [ТС] | |||
|
ne2win, спасибо за ответ!
Пожалуйста.Есть интернет-магазин. У этого магазина есть поисковая машина ElasticSearch. У эластика есть автоподсказки, как у яндекса или гугла (выпадающий список). Нужно обновить эти подсказки на основе запросов пользователей. Алгоритм действий такой: 1. Берем из БД все запросы за последние сутки. 2. По хитрой формуле считаем "вес" каждого запроса. В формуле участвуют кол-во таких запросов за сутки, кол-во найденных по запросу товаров и т.п. 3. После этого строим около 42000 объектов класса "Запрос", в которых содержится инфа: запрос, "вес", кол-во товаров и т.п. (7 полей и один ArrayList<String>) В том числе среди этих полей есть флаг "itIsRight", который свидетельствует о правильности написания запроса с точки зрения русского языка, т.е. есть ли грамматические ошибки. 4. Собственно если есть ошибки, то по отдельному алгоритму производится "слияние" правильных запросов и части инфы из неправильного и неправильный удаляется. Получается что мы имеем ArrayList<Запросы> в котором 42000 объектов <Запросы> и каждый объект сравнивается с каждым в цикле по трем разным полям. Вот такая задачка
0
|
|||
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
|
| 05.08.2016, 10:24 | |
|
Zelmm,
во-первых я бы делал запрос из БД уже с аггрегацией по запросам. Чтобы небыло повторов, а был формат "запрос" - "кол-во". Таким образом вы тянете меньше данных. Во-вторых этот алгоритм я полагаю не бежит после каждого запроса пользователя, а бежит например пару раз в сутки и бежит в фоновом режиме. Таким образом лишние пару секунд погоды не делают, а пробежать по массиву в 42к элементов это не так долго. Поэтому можете взять любой способ и не смотреть на скорость. Если же вам очень жалко памяти, делайте выборку из БД постранично. Обрабатывайте частичные данные и загружайте следующую страницу из БД. Совсем другое дело если вы хотите построить настоящую систему индексации запросов. Тут уже совершенно другие технологии. Такие как Apache Spark, HDFS, Hadoop и другие технологии для работы с BigData. Однако думаю это не ваш вариант.
1
|
|
|
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
|
|
| 09.08.2016, 10:15 [ТС] | |
|
ne2win, KEKCoGEN, спасибо за ответы.
Не без помощи Ваших советов смог разобраться с памятью
0
|
|
| 09.08.2016, 10:15 | |
|
Помогаю со студенческими работами здесь
8
Удалить все символы 'а' из слов ,длина которых равна выбранной
Удалить все символы 'а' из слов, длина которых равна выбранной
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|