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

Вниз

TServerSocket: Read error 998, Неверная попытка доступа к адресу   Найти похожие ветки 

 
Ihor Osov'yak ©   (2003-01-25 00:53) [0]

Довольно редко, но возникает...
Сокет в stThreadBlocking, чтение в потоке, созданном в SrvSocketGetThread,
код для чтения прост до безобразия, привожу, хотя вряд-ли там ошибка:



procedure TServerThread.ClientExecute;

const buffLen = 64;
var
Buffer, strIn,nextIn: string;

nRead: Integer;

...

try
Stream := TWinSocketStream.Create(ClientSocket, 180000);
try

s:=strServiceHello+strVers+" protocol="+strProtVers
+" IdSeans="+IntToStr(fID)+" Key=2"#13#10;
Stream.Write(s[1],length(s));

nextIn:="";
while not Terminated and ClientSocket.Connected do
begin
Buffer := "";
strIn := nextIn;
nextIn := "";
try
SetLength(Buffer, buffLen);
repeat
nRead := Stream.Read(Buffer[1], buffLen);

....

except
on E:Exception do Log(2,"Except in ClientThread. ID="+IntToStr(fID)
+" "+E.Message);
end;




Приложение оформлено как сервис, общаюсь с ним пока через телнет в пределах локального хоста...

... Кто чего умного может подсказать по поводу этого 998.
... Я чего-то не верю, что SetLength(Buffer, buffLen); может память не выделить... Или все же перейти к старому, доброму ShortString для Buffer? Как минимум, меньше будет дерганий для выделения памяти под строку...

Зы. Ошибка может и несколько часов не появлятся, а может раза два за 15 минут ...


 
ole ©   (2003-01-27 04:47) [1]

Насколько я помню такая ошибка происходит в случае незавершения thread"а по окончанию сеанса связи. Он продолжает считывать какие-либо данные из соединения, которое уже не существует, что и генерит эксцепшин... Попробуй уменьшить таймауты. Поставь больше проверок на наличие соединения. т.е. перед каждым чтением проверяй Connected. и читай в Try except end; по эксцепту завершай трид...


 
Ihor Osov'yak ©   (2003-01-28 12:05) [2]

> ole © (27.01.03 04:47)

Да нет, сеанс тогда еще активен.
> читай в Try except end; по эксцепту завершай трид...

так и делаю.

Зы, ошибка возникает тогда, когда общаюсь с сервисом через телнет. При работе реальной клиентской программы (там также блокирующий режим в отдельном потоке) - таких проблем нет ... Правда, одна оговорка - реальный режим работы - соединение активно только несколько секунб, возможно несколько десятков, если канал плохой, телнетом вишу как правило несколько десятков минут ...

Зы2 - если я правильно понял - то это можно интерпритировать как нормальное поведение для случая разрива сеанса по каким-то внешним причинам?



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

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

Наверх




Память: 0.47 MB
Время: 0.022 c
14-54267
uw
2003-02-27 17:58
2003.03.17
Говорят, женщины на 30% потеют меньше мужчин.


1-54088
BillyJeans
2003-03-05 13:29
2003.03.17
Новый class и его property


1-53979
MetalFan
2003-03-06 10:17
2003.03.17
С чего начать?


1-54004
X3coder
2003-03-06 14:56
2003.03.17
Как событию присвоить действия?


1-54091
sniper
2003-03-05 16:08
2003.03.17
Генератор случайных чисел