pthread の以前のスレッド ラッパーを std::thread に変換しています。ただし、c++11 にはスレッドをキャンセルする方法がありません。ただし、スレッドは外部ライブラリ内で非常に長いタスクを実行している可能性があるため、スレッドをキャンセルする必要があります。
プラットフォームで pthread_id を提供する native_handle の使用を検討していました。Linux (Ubuntu 12.10) で gcc 4.7 を使用しています。アイデアは次のようになります。
#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 によってスローされた例外によってキャンセルされます。
私の質問は:
このアプローチに問題はありますか (移植性がないこと以外に)?