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

Вниз

Блокировка потоков   Найти похожие ветки 

 
tonich   (2009-08-30 18:31) [0]

День добрый..
такой вопрос...

есть логгер который пишет в файл... (классик). внутри класса объявлена критическая секция...
есть приложение, которое из основного потока пишет в фаил, а так же открывает еще одни поток из которого так же пишется логи в фаил,  и иногда происходит блокировка основного потока, ну просто приложение виснит, а почему не могу понять...??
дополнительно поток работает с таймаутами, то есть если он и блокирует доступ к файлу (в логере , то не надолго )


 
Юрий Зотов ©   (2009-08-30 18:53) [1]

> tonich   (30.08.09 18:31)  

У меня тоже программа виснет. Не подскажете, почему?


 
tonich   (2009-08-30 19:08) [2]

))
весело

вот кусок класса логгера

procedure TLog.Log(const Sender: TObject; const LogClass: TLogClass; const LogMsg: String);
var S : String;
begin

 try

   FCritSection.Enter;
   try

...  тут происходит запись сообщения в фаил
   finally
    FCritSection.Leave;
   end;
end;

это участок вызывается как в основном так и в дополнительном потоке...

сама секция объявлена в классе логгера
сам логгер создается в основном потоке как глобальная переменная

initialization
FLogProgramm := TLog.Create(nil);
FLogProgramm.LogFileName := GetLogFilePath;

LogDebug("<============S T A R T============>");
LogDebug("initialization global unit");

finalization

LogDebug("finalization global unit");
LogDebug("<============= E N D =============>");

if Assigned(FLogProgramm) then
 FreeAndNil(FLogProgramm);

ну то то есть насколько я понимаю работу критических секций, то должно происходить примерно следующее..

если дополнительный поток пишет в фаил, то основной приостанавливается (если он конечно так же пытается писать в фаил) до тех пор пока дополнительный не освободит секцию..


 
tonich   (2009-08-30 19:10) [3]

если я что-то не правильно понимаю, поправьте меня...


 
tonich   (2009-08-30 19:52) [4]


> Юрий Зотов ©   (30.08.09 18:53) [1]


спасибо за помощь.. )) таки нашел...


 
turbouser ©   (2009-08-30 20:44) [5]


> tonich   (30.08.09 19:52) [4]

Поздравляю.



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

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

Наверх




Память: 0.47 MB
Время: 0.02 c
1-1220967073
stas
2008-09-09 17:31
2009.10.25
Работа с функциями GetWindowLong, SetWindowLong


15-1250875581
DillerXX
2009-08-21 21:26
2009.10.25
Аудио системы


2-1251965130
ford
2009-09-03 12:05
2009.10.25
TWebBrowser список ссылок ячейки таблицы


2-1251702004
wah
2009-08-31 11:00
2009.10.25
XP Style и Standard


3-1201334641
mega
2008-01-26 11:04
2009.10.25
DirectMysqlObjects (TMySQLClient, TMysqlResult) + Jpeg