【问题标题】:How to cast std::function<void(int)> to void* inside pthread_create() [duplicate]如何在 pthread_create() 中将 std::function<void(int)> 转换为 void* [重复]
【发布时间】:2019-06-05 16:35:00
【问题描述】:

我有一个如下所示的函数

我想从 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)。

【问题讨论】:

  • 一定要用pthread吗? std::thread 自然会使用 lambda。
  • 为什么不使用 args?
  • 如果 lambda 实际上是一个 lambda 表达式并且如果它没有捕获你可以获得一个函数指针,但是一旦你把它放在一个 std::function 中就没有办法得到一个函数指针返回。

标签: c++ pthreads


【解决方案1】:

您不能将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

【讨论】:

  • 是的,请。我应该在不使用 c++ 线程库的情况下做到这一点。
  • @srccode 完成,添加代码。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2014-12-11
  • 2017-07-08
  • 2018-02-26
  • 1970-01-01
  • 2019-11-19
  • 1970-01-01
  • 2016-11-20
相关资源
最近更新 更多