我有一个我不明白的问题.我有一个产生线程的类.一切都好.我做了一个新对象 - 一切都好.如果我将这些存储在一个向量中来迭代我的代码就无法编译.我用g ++ 4.9 i686.我制作了以下简短的程序,它完全模仿了问题,因为真正的代码相当广泛.如果有人能够澄清或给我一个对我的宠物项目很有帮助的解决方案,因为我坚持这个.代码如下:
#include <thread>
#include <string>
#include <iostream>
#include <vector>
class test
{
public:
test();
void setstring(std::string s);
~test() { }
void runThread() { m_thread = std::thread(&test::print, this); }
void stop() {on=false;m_thread.join(); }
private:
std::string s;
bool on=false;
std::string m_data;
std::thread m_thread;
void print();
};
test::test(){s="";m_data="";}
void test:: print() { std::cout << "I'm running" << '\n'; on = true;
while(on==true){std::cout << m_data << '\n';}
}
void test:: setstring(std::string s){m_data = s;}
int main()
{
//this works
test one ;
one.setstring("thread running");
one.runThread();
getchar();
one.stop();
std::cout << "I've stopped" << '\n';
std::vector<test> testvec;
test *tst;
tst= new test;
//testvec.push_back(*tst); //FAILES TO COMPILE
delete tst;
}
Run Code Online (Sandbox Code Playgroud)
std::vector::push_back您使用的版本需要可复制对象,您的类不可复制.原因std::thread是不可复制
thread(const thread&) = delete;
由于它是不可复制的,因此会删除类的默认复制构造函数.
要添加默认值test,testvec您可以使用std::vector::emplace_back
testvec.emplace_back();
Run Code Online (Sandbox Code Playgroud)
或者通过在呼叫中构建一个临时的 push_back
testvec.push_back(test());
Run Code Online (Sandbox Code Playgroud)
这将调用r值引用的重载 push_back()
您还需要删除构造函数和析构函数,因为它们会阻止自动创建您的类需要正常工作的移动构造函数.根据经验,如果您的类只包含POD类型或类似POD的类型(自己处理的对象),那么您不需要创建任何构造函数,因为编译器提供的类型将起作用.