отмена std :: thread с помощью native_handle () + pthread_cancel ()

Я конвертирую предыдущую оболочку потока вокруг pthreads в std :: thread.
Однако C ++ 11 не имеет никакого способа отменить поток. Тем не менее, я ТРЕБУЮ, чтобы отменить потоки, поскольку они могут выполнять очень длительную задачу во внешней библиотеке.

Я подумывал об использовании native_handle, который дает мне pthread_id в моей платформе. Я использую gcc 4.7 в Linux (Ubuntu 12.10). Идея была бы:

#include <iostream>
#include <thread>
#include <chrono>

using namespace std;

int main(int argc, char **argv) {
cout << "Hello, world!" << endl;

auto lambda = []() {
cout << "ID: "<<pthread_self() <<endl;
while (true) {
cout << "Hello" << endl;
this_thread::sleep_for(chrono::seconds(2));
}
};

pthread_t id;
{
std::thread th(lambda);

this_thread::sleep_for(chrono::seconds(1));

id = th.native_handle();
cout << id << endl;
th.detach();
}
cout << "cancelling ID: "<< id << endl;

pthread_cancel(id);

cout << "cancelled: "<< id << endl;

return 0;
}

Поток отменяется из-за исключения, созданного pthreads.

Мой вопрос:

Будут ли какие-либо проблемы с этим подходом (кроме того, что он не переносимый)?

4

Решение

Нет, я не думаю, что у вас не будет дополнительных проблем, кроме:

  • не быть портативным
  • необходимость тщательно запрограммировать _very_very_, чтобы все объекты отмененного потока были уничтожены …

Например, Стандарт гласит, что по окончании потока переменные будут уничтожены. Если вы отмените поток, это будет намного сложнее для компилятора, если не невозможно.

Я бы поэтому рекомендовал не отменить поток, если вы можете как-то избежать этого. Напишите стандартный цикл опроса, используйте переменную условия, прослушайте сигнал, чтобы прервать чтение и т. Д. — и регулярно завершайте поток.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]