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

Вниз

TIdTCPServer, TIdTCPClient   Найти похожие ветки 

 
Анонимщик ©   (2004-04-14 01:10) [0]

У сервера есть метод OnDisconnect. Я так понимаю, событие срабатывает, когда клиент отваливается? Что-то не выходит. Помогите начинающему.


 
Rouse_ ©   (2004-04-14 01:25) [1]

Ну насколько я помню данное событие происходит не когда клиент "отваливается", а когда он выполняет соответствующий метод...


 
Анонимщик ©   (2004-04-14 01:35) [2]

А как поймать отваливание?


 
Rouse_ ©   (2004-04-14 01:57) [3]

Ну давай думать логически - id предназначен дл совместимости с Linux стало быть Асинхронка тебе заказана :)
На сколько я помню работает все это в блокирующем режиме стало быть событий не ищи - вывод?
Вспоминаем как работают сокеты в данном состоянии, вот там и найдешь решение проблемы...


 
Анонимщик ©   (2004-04-14 02:02) [4]

Черт побери. Извини, я действительно редко сокетами занимаюсь. Мне ведь действительно асинхронный режим нужен.
Чем посоветуешь воспользоваться?


 
Rouse_ ©   (2004-04-14 02:13) [5]

Тут я плохой советчик, так как пользуюсь исключительно WinSock, думаю Verg или Digitman будут более компетентны...


 
Анонимщик ©   (2004-04-14 03:10) [6]

Тогда тебе спасибо.


 
Digitman ©   (2004-04-14 08:28) [7]


> Анонимщик


чем плохи TServerSocket/TClientSocket ? imho, ничем .. асинхронный режим оба поддерживают .. совершенно прозрачный транспортный механизм .. простота и наглядность .. никаких излишеств ..


 
Erik ©   (2004-04-14 09:36) [8]

А еще можно логически подумать, если клиент долго неотвечает, то можно послать ему тестовый пакет. Нет ответа значить отвалился.


 
Rouse_ ©   (2004-04-14 09:38) [9]

> [8] Erik ©   (14.04.04 09:36)
Это ж тебе не UDP...


 
Verg ©   (2004-04-14 09:56) [10]

Если говорить именно про сервер (TIdTCPServer), событие OnDisconnect возникает, когда поток созданый этим компонентом для обработки входящего клиентского подключения обнаруживает разрыв соединения.
Обнаружить это он может только если при исполнении (OnExecute) он вызывает методы Read**, Write** и т.п. прямо или косвенно.

Т.е., например, если в OnExecute делать так:

procedure TForm1.IdTCPServer1Execute(AThread: TIdPeerThread);
begin
 sleep(10);
end;

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

Блокирующие сокеты сами по-себе никому ничего не сообщают.
С ними надо "общаться", чтобы узнать о их состоянии.

Предыдущий пример заменим на

procedure TForm1.IdTCPServer1Execute(AThread: TIdPeerThread);
begin
 AThread.Connection.ReadFromStack(false, 100, false);
end;


 
Anvar Turakulov   (2004-04-21 09:40) [11]

Удалено модератором
Примечание: Последний раз повторяю. Задай свопрос в своей ветке и в ней же и жди ответа. Незачем мусорить в других...



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

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

Наверх




Память: 0.49 MB
Время: 0.021 c
1-1085068037
volkodav
2004-05-20 19:47
2004.06.06
замена цвета


14-1084704098
Феликс
2004-05-16 14:41
2004.06.06
НЛП. Чего это?


1-1085559385
Gloony
2004-05-26 12:16
2004.06.06
Типизированный файл как источник данных таблицы


1-1085656704
ЁПРСТ
2004-05-27 15:18
2004.06.06
Как в FastReport е наладить вывод StringGrid а из основной проги?


14-1085055592
studentRSU
2004-05-20 16:19
2004.06.06
Киньте ссылку на InstallShield Express