|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
Многопоточный чат с использованием пула потоков23.03.2014, 19:10. Показов 5746. Ответов 55
Метки нет (Все метки)
есть вопрос как реализовать можно чат с использованием пулов потоков.Без пула все понятно на каждого клиента создается поток и потоки висят и делают свои дела,в пуле я читал создается n-ое количество потоков и они обрабатывают свои задачи,тоесть если у меня 4 потока в пуле то только 4 пользователя смогут работать и все,а остальные будут в очереди или я не правильно что то понимаю
Добавлено через 43 минуты неужели никто не использовал пул потоков?
0
|
|
| 23.03.2014, 19:10 | |
|
Ответы с готовыми решениями:
55
Помощь с использованием потоков Обработка матриц с использованием файлов и потоков |
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 23.03.2014, 19:40 [ТС] | |
|
Jupiter,вопрос возник в том что получается у меня в системе будет только определенное количество пользователей допустим в пуле 10 потоков значит одновременно может быть только 10 клиентов,остальные клиенты подсоеденяются и ждут когда пул потоков обработает их задачу я правильно понял?
Добавлено через 7 минут Jupiter, получается что по сути лучше использовать на каждого клиента свой поток ?бесконечное количество пользователей будет,а с пулом получается нет?
0
|
|
|
Каратель
|
|||
| 23.03.2014, 19:55 | |||
|
1
|
|||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 24.03.2014, 17:17 [ТС] | |
|
Jupiter, просто у меня стоит задача курсового пул потоков,я решил на курсовую сделать чат с использованием пула,может подскажите какую-нибудь идею для курсового с использованием пула потоков?
Добавлено через 21 час 6 минут никто не подскажет?
0
|
|
|
Ушел с форума
|
||
| 24.03.2014, 21:47 | ||
|
Сетевой ввод-вывод по своей природе устроен так, что там постоянно происходит ожидание выполнения каких-то операций - пинг, handshake, connect/disconnect, send, receive и т.д. Пока сетевое оборудование занимается обработкой операции, поток разгружается и может взять на себя еще что-нибудь. Например, обработать результат операции, которая только что завершилась. После чего поток снова "возвращается" в пул. То есть, небольшое количество потоков легко могут обслуживать десятки и сотни клиентов, а иногда на порядки больше.
1
|
||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 24.03.2014, 22:34 [ТС] | |
|
Убежденный, ну это я понимаю что операция завершилась поток освободился можно взять другую задачу,а если у меня допустим 4 потока будут висеть все время и в бесконечном цикле крутиться пока клиент не дисконект то получится что очередь все таки будет
0
|
|
|
Ушел с форума
|
|
| 24.03.2014, 23:05 | |
|
Хм. А что именно будут делать эти потоки в бесконечном цикле ?
И главное - зачем ?
1
|
|
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 01:18 [ТС] | |
|
Убежденный, они будут ждать от клиента действий и опять зысыпать,а как чат сделать тогда иначе?
0
|
|
|
Ушел с форума
|
|
| 25.03.2014, 09:25 | |
|
sergeu90, очень советую - найдите книгу "Программирование в
сетях Windows", почитайте в ней главу про модели сокетного ввода-вывода, особенно что касается портов завершения (IOCP). Там вовсю используются пулы потоков и характерные "примочки", которые с ними связаны. Многие такие вопросы сами собой отпадут.
2
|
|
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
||
| 25.03.2014, 10:32 | ||
|
на сокете появилась активность на чтение - читаем писать как правило можно всегда, во время дисконнекта по моим наблюдениям появляется активность на чтение, но recv вернет 0 (0 может вернуть и в других ситуациях, важно при получении 0 байт проверить значение errno/WSAGetLastError())
0
|
||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 13:34 [ТС] | |
|
aLarman, ну я трошки не понимаю,как сделать асинхронный ввод вывод,я так и собирался делать в цикле бесконечном ждать активности от клиента,а как вот сделать иначе сложно)
Добавлено через 1 минуту Убежденный, спасибо буду пробывать читать хотя до сих не понимаю как реализовать логику чата,что бы каждый поток не висел в бесконечном цикле
0
|
|
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
||
| 25.03.2014, 13:41 | ||
|
в 2х словах, в эти ф-ции передаются дескрипторы (cокеты в вашем случае) и эти дескрипторы проверяются на активность (на чтение на запись на ошибки), и этот метод возвращает управление если есть хотя бы 1 активность, или после таймайта на запись практически всегда будет активность (потому что писать можно практически всегда - забить буфер сложно, а ошибочные ситуации рассматривать не будем) поэтому достаточно проверять активность на чтение соответственно как появилась активность на чтение даем задачу пулу обработать эту активность (вычитать данные), в данном случае если есть активность, то вызов recv не будет блокирующим после чего делаем какие то действия с полученными данными, каким то образом реагируем на эти данные (возможно вызов какой то ф-ции) и поток завершает работу (точнее начинает ждать новой задачи) что получается - есть что читать - читаем, нет ничего - простой, а опрашивать в цикле данные не стоит
0
|
||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 13:44 [ТС] | |
|
aLarman, и как тогда со стороны клиента держать соеденение что бы не отсоеденяться от сервера,так я делал что бы в потоке на сервере бесконечно крутился цикл и тогда клиент у меня не терялся тоесть не дисконектился
Добавлено через 1 минуту aLarman, а можно пример кода примитивный самый простой что бы понять как это выглядит так сложно разобраться,ели не сложно не большой пример
0
|
|
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
|
| 25.03.2014, 13:45 | |
|
0
|
|
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 13:48 [ТС] | |
|
aLarman, планирую использовать TCP и хочу вот сделать что-нибудь на курсовой вроде как чата,но вот через пул потоков,для начала мне бы понять как вы сказали активность смотреть и в пул передавать
Добавлено через 1 минуту aLarman, тоесть в пул я знаю как передавать,я собираюсь использовать winapi функции для работы с пулом
0
|
|
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
|||||||
| 25.03.2014, 13:50 | |||||||
|
вот пример с 1 потоком на accept подключений, и множеством потоков на каждое сообщение (по сути можно на каждое сообщение не поток создавать, а отдавать ф-цию которая производит чтение в пул)
ф-ция Dispatch() в цикле Вызывает select + доп. действия Добавлено через 49 секунд
1
|
|||||||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 13:53 [ТС] | |
|
aLarman, получается это не пул тут я так понял ?
0
|
|
|
654 / 575 / 164
Регистрация: 13.12.2012
Сообщений: 2,124
|
||||||
| 25.03.2014, 13:58 | ||||||
|
да, в методе Dispatch там где вызывается
1
|
||||||
|
28 / 29 / 5
Регистрация: 17.10.2009
Сообщений: 739
|
|
| 25.03.2014, 14:00 [ТС] | |
|
aLarman, спасибо начну разбираться на днях)
0
|
|
| 25.03.2014, 14:00 | |
|
Помогаю со студенческими работами здесь
20
Максимальный элемент матрицы с использованием потоков Поиск в бинарном файле с использованием файловых потоков Сервер с использованием пула потоков для параллельной обработки запросов клиентов Синхронизация пула потоков Ожидание завершения пула потоков Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|