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

Вниз

2.35 bug tthread   Найти похожие ветки 

 
grm ©   (2006-05-16 14:14) [0]

в деструкторе нити (KOL) вызывается waitfor, который вызывает еще раз деструктор, закрывает дескриптор нити, и при возвращении падаем на CloseHandle(FHandle);
 попробовал обнулить после закрытия дескриптор для корректной работы, но получаем дальше ошибку особождения памяти. судя по всему весь алгоритм зачем-то сильно исказили в последнее время...
в версии 2.33 такого не было.

destructor TThread.Destroy;
begin
 if not FTerminated then
 begin
   Terminate;
>    WaitFor;
 end;
 if (FHandle <> 0) then
   begin
     CloseHandle(FHandle);
   end;
 inherited;
end;

function TThread.WaitFor: Integer;
begin
 RefInc;
 Result := -1;
 if FHandle = 0 then Exit;
 WaitForSingleObject(FHandle, INFINITE);
 GetExitCodeThread(FHandle, DWORD(Result));
>  RefDec;
end;


 
mdw ©   (2006-05-16 14:26) [1]

В ветке http://delphimaster.net/view/11-1145208691/ обсуждали.

Я Кладову писал, но он интереса не проявил. Там что-то с  RefCount напутано, примерно в версии 2.33 он и изменил обработку. Варианта два:  подождать или использовать OLD_REFCOUNT. Я жду пока, юзаю 2.30.



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

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

Наверх




Память: 0.46 MB
Время: 0.054 c
15-1169571092
Gydvin
2007-01-23 19:51
2007.02.11
Не, заземлять сетевой кабель не поможет


1-1166546027
2expres
2006-12-19 19:33
2007.02.11
Помогите в Delphi организовать таймер на 10мс


4-1159453855
Dib@zol
2006-09-28 18:30
2007.02.11
Глюк с перерисовкой окна


2-1169312841
NikNet
2007-01-20 20:07
2007.02.11
Клонировать всю структуру базы данных с данными(можно без данных)


15-1169497825
xayam
2007-01-22 23:30
2007.02.11
Наш пров увеличил скорость в два раза))