Здравствуйте, гость ( Вход | Регистрация )
kwisp | Дата 29.3.2010, 10:54 |
DeathKnight, тут вопрос, на сколько много соединений ты хочешь обслуживать и как много данных передавать. если объемы данных не большие и соединений не много то..... если кол-во соединений большое и объемы данных велики то всё намного сложнее по-моему. если по-простому я бы попробовал сделать так. никаких потоков. -- сервер слушает порт(для гибкости порт можно передавать через параметр командной строки или гуй или файл конфигурации). как только кто-то стучится соединиться ему выделяется новый сокет с новым портом и далее общение с клиентом уже через новый сокет. -- клиент стучится на сервер:порт(заданый через гуй, командную строку, файл конфигурации) ему выделяют порт и он уже по этому порту общается сервером. -- класс сообщения с заголовком quint, вроде нормально у меня сделано так же пока сбоев не было. прочти соседние темы на счет затыков с размерами сообщений, перемешении байтов, корректном вычитывании из сокета. пробуй. пиши код сюда. П.С. зачем тебе QMap для хранения идентификаторов клиентов если не важен порядок используй QHash или вектор., можно и обычным массивом обойтись если извесно максимальное колличество клиентов. |
|
DeathKnight | Дата 29.3.2010, 10:27 |
хм.. тогда так. я придумал сделать на сервере: -простой гуи для контроля состояния. -сам tcpserver отправить в отдельный поток -для каждого сокета пользователя также отдельный поток(клиент как наследник qthread с указателем на qtcpsocket) -в объекте сервера qmap(id и ссылка на объект клиент-поток-сокет) для определения кому пересылать пришедшее сообщение - и класс сообщения, в начале которого quint, где лежит величина всего объекта, а дальше параметры(либо id от кого и кому и сообщение, либо служебные сообщения(авторизация и т.п.)) оправдан такой подход или это будет довольно сложно для реализации? пишу курсовой. |
|
kwisp | Дата 29.3.2010, 8:00 |
DeathKnight, раз не хватает стандартных примеров -- задавай конкретные вопросы. этот вопрос кроме как ссылки на примеры уж прости ничего не заслуживает. может быть, есть у кого-нибудь пример "клиент-серверной системы передачи сообщений". все, что нашел в нете, слишком сложно. тот же qutim. извините за беспокойство. за ранее спасибо. |
|
DeathKnight | Дата 28.3.2010, 23:43 |
kwisp, смотрел, просто этого мне не хватает для представления, как разработать программу. буду ковырять. спс. |
|
ViGOur | Дата 28.3.2010, 16:43 |
Посмотри: Network Examples | |
kwisp | Дата 28.3.2010, 15:18 |
DeathKnight, а стандартные примеры поставляемые с библиотекой почему не смотрим? и + поищи по форуму QTcpSocket QTcpServer QUdpSocket и проч.... для разнообразия. |
|
DeathKnight | Дата 28.3.2010, 15:12 |
может быть, есть у кого-нибудь пример "клиент-серверной системы передачи сообщений". все, что нашел в нете, слишком сложно. тот же qutim. извините за беспокойство. за ранее спасибо. |
|
Просмотр темы полностью (откроется в новом окне) | |
Текстовая версия | Сейчас: 28.3.2024, 15:40 |