调用带有带参数的类成员函数的std::thread构造函数

Calling a std::thread constructor with a class member function that takes parameters

本文关键字:std thread 构造函数 函数 参数 调用 成员      更新时间:2023-10-16

我知道存在这个问题和这个问题。这两种方法我都试过了,但都没能解决我的问题。我能够运行不带参数的类成员函数的示例,但无法推断出如果成员函数有参数,线程的构造函数会是什么样子。

我有一个类a, a有一个成员函数f,它有两个参数p1和p2。我已经实例化了类a的对象a。我想在线程中调用函数f。

From cppreference.com:

template< class Function, class... Args > 
explicit thread( Function&& f, Args&&... args );

是我必须编写构造函数的方式。

我破译上述定义有困难。如何调用定义为

的a.f(p1,p2)

void A::f(int p1, int p2)

直接传递参数:

std::thread t(&A::f, &bar, p1, p2);
t.join();

注意:注意我们正在传递bar对象的地址,否则线程构造函数会复制你的对象。通过这样做,你必须保证你的对象比你的线程更长寿。注意,其他参数也是如此。在参数的情况下,您可以简单地使用std::ref

一般来说,正如我在另一篇文章中提到的,std::thread构造函数是根据INVOKE定义(§20.8.2.1)定义的:

定义INVOKE (f, t1, t2,…), tN)如下:

  • (t1。* f) (t2,…,当f是指向类T的成员函数的指针,t1是T类型的对象或对的对象的引用时,则为tN)类型T或对从T派生的类型的对象的引用;
  • ((* t1)。* f) (t2,…当f是指向类T的成员函数的指针,且t1不是前面描述的类型之一时,则为tN)项;
  • t1。当N == 1,且f是指向类T的成员数据的指针,且t1是类型T或
    的对象时,*f对T类型对象的引用或对
    类型对象的引用
  • (* t1)。当N == 1,且f是指向类T成员数据的指针,且t1不是上一项所述的类型时,*f;
  • f(t1, t2,…)