Форум: "WinAPI";
Текущий архив: 2004.05.02;
Скачать: [xml.tar.bz2];
ВнизКак корректно уничтожить поток(Thread)? Найти похожие ветки
← →
sucer (2004-03-05 04:27) [0]Создаю 100 потоков функцией CreateThread.Потоки выполняет некий
алгоритм.В некотый момент надо всех их уничтожить
Как корректно их уничтожить?
-если уничтожая их ExitThread(ExitCode) программа закрываться,после уничтожения последнего потока.
-уничтожая TerminateThread - программа уничтожает поток,не освобожает память потока(так даже по документации написано)
← →
sucer (2004-03-05 05:51) [1]Соорри
TerminateThread - освобождает память через некоторое время...
(TerminateThread — функция ясинхронная, т, e. она сообщает системе, что Вы хотите завершить поток, но к тому времени, когда она вернет управление, поток может быть еще не уничтожен.)
← →
MBo © (2004-03-05 07:30) [2]Корректным методом завершения потока является завершение его потоковой функции. Если ее надо прервать, то посылай потоку сообщение или используй средства синхронизации (например, Events)
← →
Digitman © (2004-03-05 08:26) [3]
> sucer
корректным является выполнение поточной ф-цией WinAPI-вызова ExitThread(), при котором поток завершается и все системные ресурсы (т.е. ресурсы, выделенные системой при старте потока для обеспечения его функционирования в контексте процесса) системой же освобождаются.
другой вопрос, что поточная ф-ция должна это сделать вовремя, т.е. в тот момент когда это предусмотрено алгоритмом
это означает, что алгоритм, реализуемый поточной ф-цией, должен предусматривать некое "интерактивное" взаимодействие с другими потоками, например, с основным.
← →
DeadMeat © (2004-03-05 17:10) [4]> sucer (05.03.04 04:27)
Покажи как ты их закрываешь через ExitThread...
← →
sucer (2004-03-05 18:27) [5]1) Через TerminateThread
............
mov ebx,ThreadHandle
push ebx
invoke GetExitCodeThread,ebx,offset MesTemp3;
pop ebx
mov ecx,offset MesTemp3
mov eax,dword ptr [ecx] ;exit code
cmp eax,0
je ER1
invoke TerminateThread,ebx,eax;
cmp eax,0
jne OK
ER1:
invoke MessageBoxA, hwnd,offset MesErKillThread,offset CaptionEr,MB_OK+MB_ICONSTOP
jmp END_;
OK:
............
2) Через ExitThread
mov ebx,ThreadHandle
push ebx
invoke GetExitCodeThread,ebx,offset MesTemp3;
pop ebx
mov ecx,offset MesTemp3
mov eax,dword ptr [ecx] ;exit code
invoke ExitThread,eax;
← →
Digitman © (2004-03-06 11:47) [6]
> 2) Через ExitThread
ф-ция ExitThread() должна быть выполнена именно тем потоком, который должен завершиться, а не каким-то другим !
ф-ция GetExitCodeThread имеет смысл лишь после завершения целевого потока, а не до его завершения
← →
sucer (2004-03-06 13:04) [7]Так чтож, если поток зациклился, то его нельзя "корректно" уничтожить?
← →
TUser © (2004-03-06 13:18) [8]Его можно уничтожить через TerminateThread, но эта ф-я была придумана для аварийного фавершения потока. Насколько это "корректно" - вам решать, но ресурсы могут остаться невысвобожденными.
PS. Действительно нужно создавать столько отдельных потоков? М.б. можно как-то переделать алгоритм. Даже в больших и сложных программах больше 1-2 десятков потоков обычно не используется, а они выполняются не одновременно.
← →
Digitman © (2004-03-06 13:20) [9]ну почему ? уничтожить можно. из другого потока. вызовом TerminateThread().
Но !
Читаем хэлп :
Remarks
TerminateThread is used to cause a thread to exit. When this occurs, the target thread has no chance to execute any user-mode code and its initial stack is not deallocated. DLLs attached to the thread are not notified that the thread is terminating.
TerminateThread is a dangerous function that should only be used in the most extreme cases. You should call TerminateThread only if you know exactly what the target thread is doing, and you control all of the code that the target thread could possibly be running at the time of the termination. For example, TerminateThread can result in the following problems:
· If the target thread owns a critical section, the critical section will not be released.
· If the target thread is executing certain kernel32 calls when it is terminated, the kernel32 state for the thread"s process could be inconsistent.
· If the target thread is manipulating the global state of a shared DLL, the state of the DLL could be destroyed, affecting other users of the DLL.
p.s.
если поток у тебя "зациклился", то это говорит только об одном - алгоритм, исполняемый поточной ф-ции такого потока, неверен .. следует устранить причину зависания, изменив такой алгоритм на более правильный/корректный .. в каждой итерации цикла следует анализировать некий флаг (событие), предписывающий потоку немедленно "закругляться по хозяйству" .. при необходимости дать команду потоку на немедленное завершение некий другой поток взводит этот флаг (возбуждает соотв.событие) ... при очередной итерации цикла целевой поток обнаруживает факт взведения флага (просигналившее событие) и немедленно (как можно быстрее) реагирует на него, выходя из цикла, освобождая занятые им ресурсы (память. открытые файлы и пр.) и в конечном итоге выполняя ExitThread() .. это - самый корректный способ заставить целевой поток завершиться
Страницы: 1 вся ветка
Форум: "WinAPI";
Текущий архив: 2004.05.02;
Скачать: [xml.tar.bz2];
Память: 0.48 MB
Время: 0.032 c