Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.04.23;
Скачать: CL | DM;

Вниз

TServerSocket   Найти похожие ветки 

 
MiHoY   (2006-04-06 10:01) [0]

вот всё думаю и не могу рещить как отслеживать номера соединения пользователей
задача в том, чтобы принять сообщение от одного пользователя и отправить его другому, допустим взять из базы номер соединения этого пользователя.

но тут возникает такая загвоздка: пользователей будет очень много и простым запросом типа эй это ты с таким ID на этом соедениении не прокатит. а также имеет место простое отключение пользователей от сервера => запоминать нак номер тоже не катит


 
Сергей М. ©   (2006-04-06 10:11) [1]

Каждое соединение уникально идентифицируется по комбинации свойств RemoteAddr+RemotePort, эту комбинацию (а не номер соединения) и следует использовать для решения задачи.


 
MiHoY   (2006-04-06 11:49) [2]

пример можно
а то не догоняю малость


 
Сергей М. ©   (2006-04-06 12:15) [3]


> не догоняю малость


Что конкретно ?


 
MiHoY   (2006-04-06 12:17) [4]


> по комбинации свойств RemoteAddr+RemotePort

на эту часть


 
Сергей М. ©   (2006-04-06 12:59) [5]

Это свойства объекта TCustomWinSocket.

Того самого, который передается тебе 2-м параметром в обработчик события, например, OnClientConnect


 
MiHoY   (2006-04-06 13:07) [6]

да это знаю я
ты можешь пример использования дать


 
Сергей М. ©   (2006-04-06 13:25) [7]

Зачем пример-то, если знаешь ?

Все ж просто - когда тебе нужно отправить сообщение клиенту с таким-то требуемым адресом/портом перебираешь в цикле список Connections и для каждого элемента сравниваешь его RemoteAddress и RemotePort с искомыми.


 
MiHoY   (2006-04-06 13:27) [8]

а если их 1000000 то что?


 
Сергей М. ©   (2006-04-06 13:38) [9]


> то что?


То тоже самое.

Хотя иметь 1000000 одновременно активных клиентов твоему серверу вряд ли удастся, особенно если работает он не под управлением серверной ОС.

Только при таких условиях целесообразней будет вести собственный упорядоченный список записей с адресами, портами и ссылками на соотв.объекты, дабы осуществлять поиск в нем не банальным перебором, а с помощью любого высокоэффективного алгоритма поиска данных в упорядоченном списке. Внесение записи в список осуществляй при событии OnClientConnect, удаление - при OnClientDisconnect.



Страницы: 1 вся ветка

Текущий архив: 2006.04.23;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.058 c
15-1143637602
Yegorchic
2006-03-29 17:06
2006.04.23
Программа для моделирования дворов


3-1141126984
Рафик
2006-02-28 14:43
2006.04.23
MSSQL Distinct по дате


1-1142536791
TStas
2006-03-16 22:19
2006.04.23
А можно серверу сценариев SCRiptHost передать не ...


15-1143492305
Climber
2006-03-28 00:45
2006.04.23
Написание собственной базы данных


2-1144691948
Системщик
2006-04-10 21:59
2006.04.23
Функция CASE