Главная страница
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.042 c
2-1169473697
agfhg
2007-01-22 16:48
2007.02.11
БД


4-1159525169
RoadStar
2006-09-29 14:19
2007.02.11
Получение данных об оперативной памяти


15-1169140576
$Pl@Sh
2007-01-18 20:16
2007.02.11
У кого-нить такое было?


2-1169396785
md
2007-01-21 19:26
2007.02.11
динамический массив


15-1169300520
Ngk88
2007-01-20 16:42
2007.02.11
Ошибка "Procedure call of a function"