powered by simpleCommunicator - 2.0.49     © 2025 Programmizd 02
Форумы / Java [игнор отключен] [закрыт для гостей] / Разбить ArrayList на максимально равные по количеству элементов части
2 сообщений из 27, страница 2 из 2
Разбить ArrayList на максимально равные по количеству элементов части
    #39829126
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: java
1.
2.
3.
100 / 5 = 20 + 20 + 20 + 20 + 20
101 / 5 = 20 + 20 + 20 + 20 + 21
13 / 4 = 3 + 3 + 3 + 4


Тут - простой алгоритм. Целочисленного деления и остатка (%) достаточно.
...
Рейтинг: 0 / 0
Разбить ArrayList на максимально равные по количеству элементов части
    #39831678
UScorp
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Кажется мне, что все же использовать пул потоков будет правильнее.

Разным потокам может быть выделено разное кол-во ресурсов и отработать они могут за разное время.

Допустим надо будет вставить 10к записей в 5 потоков, дадим каждому потоку по 2к записей и запустим их одновременно. Первый поток выполниться за 1мин, второй за 3 мин, третий за 2мин, четвертый за 2,5 мин, а пятому не повезло, его все кругом ущемляют и он выполнился за 10 мин.

Тогда получается, что 7-8 минут работал только один "ущербный" поток, а остальные потоки ему не помогали.
Если бы мы раздробили данные на более мелкие порции (допустим по 200 записей), то более быстро освободившийся поток мог бы взять следующую небольшую порцию. Тогда они бы завершили свою работу все более или менее равномерно.

Добавлю - это все ИХМО ))))
...
Рейтинг: 0 / 0
2 сообщений из 27, страница 2 из 2
Форумы / Java [игнор отключен] [закрыт для гостей] / Разбить ArrayList на максимально равные по количеству элементов части
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]