7

我正在将 pthreads 的先前线程包装器转换为 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 抛出的异常取消。

我的问题是:

这种方法会有什么问题(除了不便携)?

4

1 回答 1

4

不,我认为您不会遇到以下问题:

  • 不便携
  • 必须仔细编程 _very_very_ 被取消线程的所有对象都被销毁......

For example, the Standard says that when a thread ends variables will be destroyed. If you cancel a thread this will be much harder for the compiler, if not impossible.

I would, therefore recommend not to cancel a thread if you can somehow avoid it. Write a standard polling-loop, use a condition variable, listen on a signal to interrupt reads and so on -- and end the thread regularly.

于 2012-11-26T11:34:22.427 回答