|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
Многопоточный чат с использованием пула потоков23.03.2014, 19:10. Показов 6041. Ответов 55
Метки нет (Все метки)
есть вопрос как реализовать можно чат с использованием пулов потоков.Без пула все понятно на каждого клиента создается поток и потоки висят и делают свои дела,в пуле я читал создается n-ое количество потоков и они обрабатывают свои задачи,тоесть если у меня 4 потока в пуле то только 4 пользователя смогут работать и все,а остальные будут в очереди или я не правильно что то понимаю
Добавлено через 43 минуты неужели никто не использовал пул потоков?
0
|
|
| 23.03.2014, 19:10 | |
|
Ответы с готовыми решениями:
55
Помощь с использованием потоков Обработка матриц с использованием файлов и потоков |
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
|
| 25.03.2014, 14:00 | |
|
1
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 05.11.2022, 21:38 | ||
|
Предположим созданы 10 потоков, усыплены, потом предположим подключились 10 клиентов и просто условно 5 минут занимают каждый по своему соединению, то есть свободных потоков нет. И как это реализуется ? Вам же все равно нужно вызвать фикцию прослушивать "accept", а для нее создать сокет, но ведь все 10 сокетов уже созданы и заняты, а значит 11 сокет создавать нельзя. Что именно Вы советовали поместить в очередь ?
0
|
||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
||
| 05.11.2022, 21:47 | ||
|
Не по теме: Optimus11, у человека последняя активность в 2017. Он вам не ответит. Тем не менее я ответить могу, потому что это известный паттерн и не он его придумал.
1
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 05.11.2022, 22:50 | ||
|
0
|
||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
||
| 05.11.2022, 23:06 | ||
|
0
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 06.11.2022, 12:46 | ||
|
Или я просто не понимаю тогда, как по другому.
0
|
||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
||
| 06.11.2022, 13:06 | ||
|
Если это новый клиент, то под него будет новый сокет. Естественно он будет открыт. Если этой старый клиент в очереди, то сокет под него не закрыт. Клиент просто ждет, когда его обслуживание на сервере начнется. Это активное ожидание. Итого не понятно в чем вы видите проблему.
0
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||
| 06.11.2022, 13:15 | |||
|
-Я создаю-выделяю память под сокет и ставлю его на прослушивание. -Приходит Входящие "сообщение" от Клиента - я читаю и отвечаю - после чего закрываю сокет и освобождаю ранее выделенную под него память. -Создаю-выделяю новый сокет и ставлю его на прослушивание ... -Приходит Входящие "сообщение" -итд итд Вот эти непрерывные выделения памяти и освобождение под непрерывно создающиеся и уничтожающиеся сокеты - к фрагментации памяти в итоге не приведут ?
0
|
|||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
||||
| 06.11.2022, 13:32 | ||||
|
С другой стороны в условном "чате" какая-то особенная многопоточность тоже не нужна. Как вариант можно сделать пулы клиентов на N штук в каждом, каждый пул - это отдельный поток. Пихать одного клиента чата в отдельный поток, даже временно, это расточительно. Нет там такой нагрузки.
0
|
||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||||
| 06.11.2022, 13:40 | ||||||||
Может быть ранее закрытий сокет можно переиспользовать для нового соединения ? Можно ли его как то "сбросить" в первоначальное состояние, как будто бы его только что создали ?
0
|
||||||||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
||||
| 06.11.2022, 13:52 | ||||
|
Конечно можно. Но не в вектор, естественно, а в правильно написанный пул памяти. В том же бусте есть аллокаторы на пулах. Добавлено через 2 минуты
0
|
||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||||||
| 06.11.2022, 13:55 | |||||||
|
Почему в вектор поместить объект бустовского сокета нельзя, а в специально написанный можно ?
0
|
|||||||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
|
| 06.11.2022, 14:00 | |
|
0
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 06.11.2022, 14:06 | ||
|
0
|
||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
|
|||||||
| 06.11.2022, 14:23 | |||||||
|
https://www.boost.org/doc/libs... index.html https://en.wikipedia.org/wiki/Free_list Еще есть вот такая вариация на тему:
1
|
|||||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||
| 06.11.2022, 15:24 | ||||||
|
Спасибо, однако таки не понятно, каким образом "запихнуть" бустовский сокет в этот пул памяти.
Если бустовский сокет можно создать только таким образом:
0
|
||||||
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
|
| 06.11.2022, 15:35 | |
|
0
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||||||
| 06.11.2022, 15:42 | |||||||
0
|
|||||||
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
||
| 06.11.2022, 16:01 | ||
|
У вас проблема не в этом.
0
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|
| 06.11.2022, 16:08 | |
|
0
|
|
| 06.11.2022, 16:08 | |
|
Максимальный элемент матрицы с использованием потоков Поиск в бинарном файле с использованием файловых потоков Сервер с использованием пула потоков для параллельной обработки запросов клиентов Синхронизация пула потоков Ожидание завершения пула потоков Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу)))
Критические ошибки, мешающие компиляции и. . .
|
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата)
Этот документ предназначен для того, чтобы новый чат Claude мог продолжить
работу без необходимости заново разбираться в. . .
|
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса
Калибровка параметров симбиотической модели: технический обзор
Содержание:
Введение
Постановка проблемы
Технические аспекты реализации
Процесс внедрения изменений
|
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0»
https:/ / ibb. co/ NnkGpfMd
Представленная интегрированная схема описывает непрерывную нелинейную. . .
|
|
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы
### Аннотация
Представлено исследование по разработке агентной модели микоризной. . .
|
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики
Контекст
Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
|
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии
Введение
Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
|
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np
class PlantAgent:
def __init__(self, name, strategy, initial_biomass):
self. name = name
self. strategy = strategy # "greedy" (широколиственные) или. . .
|