QThread, QEvent, QTcpServer, взаимодействия между потоками |
Здравствуйте, гость ( Вход | Регистрация )
QThread, QEvent, QTcpServer, взаимодействия между потоками |
512es |
10.11.2008, 16:00
Сообщение
#1
|
Участник Группа: Участник Сообщений: 135 Регистрация: 31.10.2008 Пользователь №: 407 Спасибо сказали: 5 раз(а) Репутация: 0 |
всем привет!
пишу многопоточный высокопроизводительный сервер на qt. сервер прослушивает коннекты на определённый порт и на каждое входящее соединение создаёт отдельный поток. при каждом пришедшем пакете поток отсылает главному потоку сообщение через customEvent. вроде работает, только не знаю как правильнее заставить все дочерние потоки (или один выборочно) отослать определённый пакет клиентам? закинул все потоки массив QVector и передаю в customEvent главного потока ид того кто отправил. правильный путь ли я выбрал? |
|
|
512es |
12.11.2008, 0:43
Сообщение
#2
|
Участник Группа: Участник Сообщений: 135 Регистрация: 31.10.2008 Пользователь №: 407 Спасибо сказали: 5 раз(а) Репутация: 0 |
Цитата(Litkevich Yuriy) если авторизованый пользователь начнет гадить, то навредит только десятерым потенциальная дыра.. таким способом можно по 9 пользователей убивать за заход =) значит, вместо QVector теперь использую QHash (быстрее икать пользователя по иду) дочерние потоки очень хорошо и удобно передают данные главному через customEvent. мало того, евенты складываются в очередь и это тоже меня устраивает. т.е. обрабатываются в порядке поступления. а вот отправка данных потоку не получается у меня как надо.. если вызывать метод напрямую через указатель на поток, хранящийся в QHash они выполняются всё равно в главном потоке. если эмитом вызывать слот результат такой же через сигнал\слот что то не получилось, т.к. надо передать ещё несколько переменных.. пробовал в дочерние потоки вставлять обработчик customEvent, эвенты приходят но всё равно выполняются в главном потоке =( в результате отсылка пакета 100 пользователям происходит очень долго. не смотря на то что они все подключались через локалхост. было бы идеальным быстро распарралелить по всем потокам процедуру отправки пакета по tcp не ждать отправки каждого.. завтра попробую в класс дочерних потоков добавить некую очередь, защищённую мьютексом, в которую буду добавлять пакеты, ожидающие отправки.. ииии... как то всётаки надо сообщить потоку о том что пора отправлять пакет =( не пойму, почему я не могу из родительского потока пробиться в дочерний?? |
|
|
Текстовая версия | Сейчас: 9.11.2024, 3:44 |