Re: Управление потоками
От: Мишень-сан  
Дата: 14.04.11 12:07
Оценка:
Здравствуйте, Аноним, Вы писали:

А>привет.

А>как корректно завершить работу потока?
А>допустим, в потоке выполняется операция.. обработка файла в 10Гб. Как мне правильно отменить/завершить операцию?
А>Потоки сделаны на boost::thread
А>варианты:
А>1. Можно постоянно проверять объект синхронизации на доступность.
А>2. Можно натыкать boost::this_thread::interrupt_point() и вызывать последовательность
А>
А>boost::thread::interrupt();
А>boost::thread::join();
А>

А>3. некий флаг завершения, который нужно постоянно проверять в потоке.

А>Но все эти решения неуниверстальны и не дают возможности остановить операцию сразу же по требованию (т.е. работает, пока флаг не будет проверен).

А>Самый корректный вариант натыкать вызовов boost::this_thread::interrupt_point() и ловить исключение?

Есть два основных способа прибить поток:
1. Ввести флаг, который будет проверяться процедурой потока. В случае взведённого флага — завершение. Если не ошибаюсь, interruot_point() + interrupt() как раз этот механизм и реализуют, через выброс исключения. Плюсы: все объекты могут быть корректно уничтожены. Минусы: требуется работа ручками.
2. Грязный хак с TerminateThread сотоварищи. Плюсы: прибивает поток мгновенно. Минусы: оставляет кучу мусора и захваченных висящих ресурсов.
Вариант №2 использовать крайне не рекомендуется:

If the target thread owns a critical section, the critical section will not be released.
If the target thread is allocating memory from the heap, the heap lock 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.

 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.