Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате |
Форум программистов > Java: Общие вопросы > Приоритет в пуле потоков, основанный не на CPU |
Автор: leniviy 3.5.2014, 12:53 |
Я хочу сделать http downloader, который скачивает одновременно несколько файлов, но с разным приоритетом. Пока файл с высоким приоритетом скачивается, скорость остальных закачек должна быть сильно урезана, но не полностью, чтобы сервер не разорвал соединение. Мне нужен планировщик задач, который при вызове функции, скажем, checkpoint(), из одного из тредов, сначала попытается найти и разбудить другой тред, который спит слишком долго, а если такого нет, то разбудить тред с наивысшем приоритетом, а текущий тред усыпить. Можно в той же функции checkpoint() передавать в планировщик количество скачанных байтов (типа как обычный планировщик считает количество циклов проца), чтобы он мог точнее расчитывать приоритеты, но это не обязательно. |
Автор: JDmitry 21.5.2014, 12:43 |
Если ваши задачи по закачке наследуются от Thread, то можете вызывать метод Thread.setPriority и указать приоритет основываясь на внутренних переменных, таких как объем скачанной информации и прочее. Если же вы хотите это делать через ThreadPoolExecutor, то вам нужно будет создать ThreadFactory,который будет создавать вышеописанные Thread на основе ваших данных и указать его в качестве аргумента в конструкторе ThreadPoolExecutor |