Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35

Удалить все объекты у которых переменная равна false

04.08.2016, 15:21. Показов 1386. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, форумчане.
Вопрос связанный с памятью:

Есть около 43000 объектов у которых есть переменная булева типа.
С определенными целями мы бегаем по ArrayList из этих объектов.
В конце концов нам надо будет удалить все объекты у которых эта переменная false.

Как нам сделать это с наименьшими затратами памяти:
Так:
Java
1
2
3
4
5
6
7
ArrayList<Object> arr = new ArrayList<>();
for (int i = 0; i < arr.size(); i++){
 
// Тут мы что-то делаем нам нужное
 
if (!arr.get(i).flag) arr.remove(i--);
}
Или так:

Java
1
2
3
4
5
6
7
ArrayList<Object> arr = new ArrayList<>();
for (int i = 0; i < arr.size(); i++){
 
// Тут мы что-то делаем нам нужное
 
}
arr.removeIf(x -> !x.flag);
Добавлено через 2 часа 22 минуты
UPD: Нашел ссылку на хабрастатью, где говориться про то, что нежелательно использовать много split()'ов: Типичные случаи утечки памяти в Java
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.08.2016, 15:21
Ответы с готовыми решениями:

Продолжение сканирования на Bitmap изображение, если переменная равна false
if (success == false) { // } if (success_2 == false) { ...

Удалить все столбцы, сумма элементов которых равна X
Удалить все столбцы, сумма элементов которых равна X. помогите написать программу

Удалить из массива все серии, длина которых равна K
Здравствуйте! прошу помочь с выполнением первого пункта задачи...Начало положено. Но не корректно выводит. Условие: Задан...

7
 Аватар для RAFA91
-28 / 35 / 25
Регистрация: 14.06.2013
Сообщений: 1,452
04.08.2016, 15:45
Цитата Сообщение от Zelmm Посмотреть сообщение
ArrayList<Object> arr = new ArrayList<>();
for (int i = 0; i < arr.size(); i++){
// Тут мы что-то делаем нам нужное
if (!arr.get(i).flag) arr.remove(i--);
}
а приводить не собераешся ?
0
 Аватар для ne2win
206 / 206 / 71
Регистрация: 25.02.2014
Сообщений: 569
04.08.2016, 15:56
Цитата Сообщение от Zelmm Посмотреть сообщение
Так же второй вопрос связанный с памятью...
Как нам сделать это с наименьшими затратами памяти:
При удаление память не затрачивается, так надо понимать.
0
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
04.08.2016, 17:40  [ТС]
RAFA91, немного не понял вопроса. В смысле "приводить"?

ne2win, да, просто ситуация в том, что в Java я очень сильный новичок и не знаю тонкостей, а приложение жрет память как подорванное, соответственно нужно освободить уже не использованную как можно быстрее. Не плавнее - черт с плавностью, а именно быстрее.
Соответственно вопрос можно переформулировать, как "В каком из двух вариантов у нас к точке Х окажется больше памяти"?
Точка Х в первом случае сразу после цикла, во втором - после окончания работы метода removeIf();
0
 Аватар для ne2win
206 / 206 / 71
Регистрация: 25.02.2014
Сообщений: 569
04.08.2016, 17:50
Лучший ответ Сообщение было отмечено Zelmm как решение

Решение

Цитата Сообщение от Zelmm Посмотреть сообщение
В каком из двух вариантов у нас к точке Х окажется больше памяти"?
Точка Х в первом случае сразу после цикла, во втором - после окончания работы метода removeIf();
В общем случае, думаю, одинаково. Память освобождается только в том случае когда это 'необходимо'.
Цитата Сообщение от Zelmm Посмотреть сообщение
Есть около 43000 объектов у которых есть переменная булева типа.
Полностью задачу можете привести?
1
11 / 2 / 0
Регистрация: 20.07.2016
Сообщений: 35
05.08.2016, 09:27  [ТС]
ne2win, спасибо за ответ!
В общем случае, думаю, одинаково. Память освобождается только в том случае когда это 'необходимо'.
Т.е., если я правильно понял, когда JVM увидит, что место в куче заканчивается, он запустить GC, который пробежится и удалит объекты без ссылок. А до того момента, пока место в куче еще есть, JVM рыпаться не будет, верно?

Полностью задачу можете привести?
Полностью? Пожалуйста.

Есть интернет-магазин. У этого магазина есть поисковая машина ElasticSearch. У эластика есть автоподсказки, как у яндекса или гугла (выпадающий список). Нужно обновить эти подсказки на основе запросов пользователей.

Алгоритм действий такой:
1. Берем из БД все запросы за последние сутки.
2. По хитрой формуле считаем "вес" каждого запроса. В формуле участвуют кол-во таких запросов за сутки, кол-во найденных по запросу товаров и т.п.
3. После этого строим около 42000 объектов класса "Запрос", в которых содержится инфа: запрос, "вес", кол-во товаров и т.п. (7 полей и один ArrayList<String>) В том числе среди этих полей есть флаг "itIsRight", который свидетельствует о правильности написания запроса с точки зрения русского языка, т.е. есть ли грамматические ошибки.
4. Собственно если есть ошибки, то по отдельному алгоритму производится "слияние" правильных запросов и части инфы из неправильного и неправильный удаляется.

Получается что мы имеем ArrayList<Запросы> в котором 42000 объектов <Запросы> и каждый объект сравнивается с каждым в цикле по трем разным полям.

Вот такая задачка
0
Эксперт Java
 Аватар для KEKCoGEN
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.08.2016, 10:15
Помогаю со студенческими работами здесь

Удалить все символы 'а' из слов ,длина которых равна выбранной
Удалить все символы 'a' из слов ,длина которых равна выбраной

Удалить из массива все столбцы, в которых сумма элементов равна 0
Добрый день. Имеется массив NxM, заполненный 0 и 1. Необходимо написать процедуру, которая удалит из массива все столбцы, в которых сумма...

Удалить все символы 'а' из слов, длина которых равна выбранной
Помогите пожалуйста как написать программу в которой требуется &quot;Удалить все символы 'а' из слов, длина которых равна выбранной&quot; при...

Удалить из массива все элементы , в которых последняя цифра равна 0
Дан массив целых чисел(n=10),заполненный случайным образом числами из промежутка . 1)Удалить из него все элементы , в которых последняя...

Удалить из массива все элементы, в записи которых последняя цифра равна 0
Дан массив целых чисел из n элементов, заполненный случайным образом числами из промежутка . Удалить из него все элементы, в записи которых...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
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/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru