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

Вниз

Indy10 WriteFile и синхронизация   Найти похожие ветки 

 
BanderLog   (2006-06-01 07:24) [0]

Привет мастерам!
Пытаюсь написать простенькую прогу по передаче фалов по TCP.
Использую TIdTCPServer и TIdTCPClient. Возникла проблема синхронизации с основным потоком (для отображения процесса передачи файла и ведения лога).
При налиции в исходном коде на клиентской стороне функции WriteFile, при попытки синхронизации приложение просто "уходит в себя". Если закоментировать её, то код отрабатывает нормально. Если раскоментировать, то "уходит в себя" при первом попытке синхронизации (...Synchronize( AddToLog)). за долго до того пока дело дойдет до самой WriteFile.
В чем может быть дело?

В том же самом коде если убрать все выводы в лог, оставив WriteFile, код отрабатывает нормально.


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


> BanderLog   (01.06.06 07:24)


Отладчик на что существует, как думаешь ?


 
BanderLog   (2006-06-01 12:16) [2]

Проблема почти разрешилась. Одновременная работа (в одной программе) сервера и клиента вызывает данный эффект. При запуске двух копий программы и использовании одной в качестве сервера, а другой как клиент, все работает прекрасно. :(
Вот такие пироги.


 
BanderLog   (2006-06-01 12:18) [3]


> Отладчик на что существует, как думаешь ?

А я сказал на каком этапе подвисает. На вызове метода Synchronize.


 
Сергей М. ©   (2006-06-01 12:24) [4]


> данный эффект


"данный эффект" - это просто ошибки в программе.


> я сказал на каком этапе подвисает. На вызове метода Synchronize


Synchronize() - не атомарная операция.
Следует четко представлять, что происходит в ее "потрохах".
На то как раз есть отладчик и исх.текст класса TThread


 
BanderLog   (2006-06-01 12:28) [5]

во время отладки доходит только до Synchronize и подвисает.


 
BanderLog   (2006-06-01 12:33) [6]

к тому же в дааном случае используются его наследки от Indy 10, исходников которых у меня нет нет.


 
umbra ©   (2006-06-01 12:39) [7]


> исходников которых у меня нет

как нет? инди есть, а исходников нет?


 
BanderLog   (2006-06-01 12:52) [8]

Да действительно, нашёл исходники, но как заствить при отладке дебагер заходить и в них?


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


> BanderLog   (01.06.06 12:52) [8]


Тебе и заходить туда не надо - достаточно поставить брпейкпойнт в начало тела метода AddToLog()


 
BanderLog   (2006-06-01 13:16) [10]

:))))) Увы не доходит он до этой процедуры, зависает где то в недрах Synchronize. Причем Делфи 2005 показывает что запускается и потом закрывается процесс какой-то, но увы приложение висит.


 
Сергей М. ©   (2006-06-01 13:24) [11]


> BanderLog   (01.06.06 13:16) [10]


> не доходит он до этой процедуры


Значит основной поток твоего приложения в это время чем-то занят и не реагирует на Win-сообщения.

Это и есть та самая ошибка.


 
BanderLog   (2006-06-01 13:24) [12]

Ага, осталось узнать чем, и как на это влияет процедура WriteFile.


 
Сергей М. ©   (2006-06-01 13:28) [13]


> осталось узнать чем


Это (за полным отсутствием кода) - к телепатам.


> как на это влияет процедура WriteFile


Никак.



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

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

Наверх




Память: 0.49 MB
Время: 0.029 c
3-1156941283
tytus
2006-08-30 16:34
2006.10.29
Как правильно создать пользователя.


8-1143445304
zxcv
2006-03-27 11:41
2006.10.29
Chart 3D


6-1149315294
wsxedc
2006-06-03 10:14
2006.10.29
Как передавать из программы параметры методами GET/POST?


1-1158744914
Старик
2006-09-20 13:35
2006.10.29
Почтовый клиент по умолчанию


2-1161002759
Андрей Иванов
2006-10-16 16:45
2006.10.29
Раскраска столбцов в StringGrid