C++11 线程:在构造函数中启动并在析构函数中加入
C++11 thread: start in constructor and join in destructor?
我正在尝试将C++11线程声明为类成员,以便我可以"分配"函数以开始执行,例如在构造函数中,我可以在析构函数中加入线程。
我该怎么做?我已经将线程声明为成员,但我正在努力为线程分配要调用的函数?
伪:
class X{
public:
X(){
t1(&X::func, this);
t2(&X::func, this);
}
~X(){
t1.join();
t2.join();
}
void func(){
//Does stuff
}
std::thread t1;
std::thread t2;
};
以通常的方式在构造函数的初始化器列表中初始化它们:
X() : t1(&X::func, this), t2(&X::func, this) {}
或者,若要确保首先初始化所有成员,请将它们保留为默认初始化,然后在构造函数的主体中重新分配它们:
X(){
t1 = std::thread(&X::func, this);
t2 = std::thread(&X::func, this);
}
>&X::func
不是一个可调用的对象,而是一个成员函数偏移量。必须使用绑定成员函数指针来实现所需的结果。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++11 线程:在构造函数中启动并在析构函数中加入
- 父类析构函数删除具有外部启动元素的子类
- 在成员函数上启动线程时不需要的析构函数调用
- 我已经启动了线程,但它多次调用析构函数,为什么?