Главная страница
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.028 c
15-1187353731
Megabyte
2007-08-17 16:28
2007.09.16
Компоненты JCL с Torry


15-1187600290
Наташа
2007-08-20 12:58
2007.09.16
Обращение к мадератором


2-1188118767
ins
2007-08-26 12:59
2007.09.16
HexToInt


15-1187538724
Piter
2007-08-19 19:52
2007.09.16
Очень классная иллюзия


2-1187817268
nord489
2007-08-23 01:14
2007.09.16
MainMenu и PopupMenu