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

Вниз

indiclient.lastcmdresult   Найти похожие ветки 

 
malyar   (2007-08-21 22:34) [0]

всем привет
есть код
------------------------------
idclient.sendcmd(....)
idclient.lastcmdresult
------------------------------
народ подскажите может ли происходить выход из lastcmdresult
раньше чем сервер ответит на запрос sendcmd,
если idclient.readtimeout=0 и на форму помещен инди антифризе.
если может то при каком условии ?


 
Сергей М. ©   (2007-08-22 08:35) [1]


> выход из lastcmdresult


Вообще-то это свойство.

Все что происходит при чтении этого св-ва - это чтение приватного значения поля FLastCmdResult.


 
Сергей М. ©   (2007-08-22 09:19) [2]

Вопрос поставлен неверно.

На строчку idclient.lastcmdresult можно попасть только и только в том случае, когда уже получен ответ сервера.

Антифриз здесь вообще ни причем.


 
malyar   (2007-08-23 00:04) [3]

в общем ситуация такая
моя процедура в которой используются
sendcmd и lastcmdresult
вызывается по таймеру с интервалом 50мс,
передаётся камонда sendall или sendto (выбираются по randomize),
сервер на них отвечает либо sendall ok  либо sendto ok (пока ничего другого он не делает)
и иногда происходит такая вещ :
на запрос sendall получаю ответ sendto ok  и наоборот
если подключено менее 10 клиентов (array of tidtcpclient)
этого не происходит
а чем больше клиентов тем чаще кривые ответы.
складывается такое ощущение что пока сервер думал как ответить на первый запрос то успел получить и ответить на второй от одного и тогоже клиента


 
Германн ©   (2007-08-23 00:31) [4]


> в общем ситуация такая
> моя процедура в которой используются
> sendcmd и lastcmdresult
> вызывается по таймеру с интервалом 50мс,
>

Ох как я не люблю таких реализаций! При возможности использования асинхронной работы использовать таймеры + синхронные методы? Тут может сложится масса "очучений". Лучше уж обкуриться. :(
А по сути надо разбираться. Вести логи как на сервере, так и на клиентах.


 
Сергей М. ©   (2007-08-23 08:10) [5]


> malyar   (23.08.07 00:04) [3]


У тебя ошибка в 17-й строке.

Инди работает в блок.режиме, асинхронность исключена.


 
Сергей М. ©   (2007-08-23 08:12) [6]


> malyar   (23.08.07 00:04) [3]


Хотя - стоп...
Вру.

Ты антифриз упомянул и таймер.
С учетом этих обст-в ситуация с "перепутом" запросто возможна.

Меняй логику.


 
malyar   (2007-08-24 23:24) [7]

to сергей
данная логика выбрана специально чтоб выявить возможные баги ,
таймер использовался в качестве БОТОВОДА.

антифризе и таймер действительно не совместимы именно их совокупность
и давала непредсказуемость поведения проге !!



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

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

Наверх




Память: 0.48 MB
Время: 0.025 c
15-1187519778
ArtemESC
2007-08-19 14:36
2007.09.16
Спикер ПК


9-1159992883
К8
2006-10-05 00:14
2007.09.16
GUI


15-1187700376
сейчас_злой
2007-08-21 16:46
2007.09.16
Ищу работу... есть опыт програмирования на Delphy


9-1143755210
netboy
2006-03-31 01:46
2007.09.16
Создание движка игры


15-1187157921
Вопрошающий
2007-08-15 10:05
2007.09.16
Помогите упростить код