如何在pthread_create()中将std :: function <void(int)>转换为void *

时间:2019-01-10 18:34:43

标签: c++ pthreads

我有一个如下所示的功能

我想从pthread创建的线程中调用lambda表达式。

void parallel(int start, int end, std::function<void(int)&&lambda, int noThreads>){
....
....
pthread_create(&threadid, NULL, startRoutine, args);//Want to call lambda(1) from the created thread
lambda(2);//Works fine from the main thread
....
....
}

如何将我的lambda函数传递给线程的startRoutine?并从startRoutine中调用lambda(1)?。

1 个答案:

答案 0 :(得分:2)

您不能将std::function强制转换为函数指针。但是您可以使用std::thread,它将与包括std::function在内的任何可调用对象一起使用。

如果出于某种原因不能使用std::thread,则可以在其中创建一个本地类和一个静态成员函数来调用std::function

以下内容:

#include <functional>
#include <pthread.h>

void parallel(std::function<void(int)>&& lambda){
    struct caller {
        static void* callme_static(void* me) {
            return static_cast<caller*>(me)->callme();
        }
        void* callme() {
            callable(arg);
            return nullptr;
        }
        caller(std::function<void(int)> c, int a) : callable(c),
                                                      arg(a)   {}

        std::function<void(int)> callable;
        const int arg;
    };
    pthread_t threadid;

    int arg = 0;
    caller c(lambda, arg);

    //Want to call lambda(1) from the created thread
    pthread_create(&threadid, NULL, &caller::callme_static, &c);
}

可以将其概括为通用调用程序,但这正是std::thread所做的,因此,如果需要通用调用程序,则可以简单地复制粘贴std::thread