170 похожих чатов

В какой-нибудь либе есть тредпул с динамическим кол-вом потоков? Хочу

иметь возможность задавать минимальное и максимальное кол-во потоков.

Я такое пока что только в POCO видел. мб ещё какие варианты есть

18 ответов

21 просмотр

C++ Rest SDK, cppcoro, boost::threadpool

Alexander "SonnySlave"-Zaitsev Автор вопроса
Anatoly Shirokov
C++ Rest SDK, cppcoro, boost::threadpool

но ведь в бусте и cppcoro (насколько я вижу по static_thread_pool) кол-во потоков не меняется в зависимости от нагруженности пула

Alexander "SonnySlave" Zaitsev
но ведь в бусте и cppcoro (насколько я вижу по sta...

А, если тебе динамическая подстройка требуется, тогда Qt посмотри еще

Alexander "SonnySlave"-Zaitsev Автор вопроса
Anatoly Shirokov
А, если тебе динамическая подстройка требуется, то...

о, точно. слона то я и не приметил. Спасибо! (пойду смотреть на интерфейсы и копировать себе :(

Если устраивает завязка на платформу, есть Thread Pool API под виндой и Grand Central Dispatch для mac. В линуксе вроде нет подобного api.

Alexander "SonnySlave"-Zaitsev Автор вопроса
magras
Если устраивает завязка на платформу, есть Thread ...

Не, требуется кроссплатформа (linux, win, mac, freebsd)

Folly thread pool executor(cpu thread pool executor)

Хм... попахивает архитектурной проблемой: Если приложение CPU bound, то увеличение количества потоков больше чем ядер проца ничего не даст. Уменьшение потоков сэкономит в самом лучшем случае ~~4 мегабайта на поток (что кажется сомнительным выигрышем), и не улучшит потребление CPU Если приложение IO bound, то решать надо не через увеличение количества потоков, а через асинхронность. Если что-то среднее - то тоже скорее всего через асинхронность. Что за задача решается?

🐙 Antony Polukhin
Хм... попахивает архитектурной проблемой: Если при...

Кажется основная идея в том, чтобы выдавать потоки лениво по появлению задач и завершать если они не нужны какое то время(https://github.com/facebook/folly/commit/68a6b5b55b177ae5d9c60a65f9e79f3eb57d10af). На самом деле если у нас несколько инстансов тредпула, ну например несколько приложений запущено в системе, это может быть выгодно по памяти, да и планировщику будет попроще наверно. Хотя я согласен, что оптимизация несколько сомнительная и я бы много мерял прежде чем так делать. Да и какие там цифры ставить тоже не очень понятно (1 - process count ?)

Alexander "SonnySlave"-Zaitsev Автор вопроса
🐙 Antony Polukhin
Хм... попахивает архитектурной проблемой: Если при...

Задача именно такая и решается: написать тредпул такой. Не спрашивайте меня зачем - он там такой не нужен. Но написать надо

Alexander "SonnySlave" Zaitsev
Задача именно такая и решается: написать тредпул т...

Может тогда не писать свой, а взять откуда то? Или по лицензии не подходит? Странно это все.

Alexander "SonnySlave"-Zaitsev Автор вопроса
Arelav
Может тогда не писать свой, а взять откуда то? Или...

Ну вот я вижу, что только от poco взять и могу

Alexander "SonnySlave"-Zaitsev Автор вопроса
Arelav
Выше ссылка на folly

О, нормас. Посмотрю туда. Мб оттуда скопирую

Мб tbb::task_arena?

Alexander "SonnySlave"-Zaitsev Автор вопроса
Alexander "SonnySlave"-Zaitsev Автор вопроса
Danya🔥
Мб tbb::task_arena?

хм, посмотрю, спасибо

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
1
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Карта сайта