我有一个我不明白的问题.我有一个产生线程的类.一切都好.我做了一个新对象 - 一切都好.如果我将这些存储在一个向量中来迭代我的代码就无法编译.我用g ++ 4.9 i686.我制作了以下简短的程序,它完全模仿了问题,因为真正的代码相当广泛.如果有人能够澄清或给我一个对我的宠物项目很有帮助的解决方案,因为我坚持这个.代码如下:
#include#include #include #include 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 testvec; test *tst; tst= new test; //testvec.push_back(*tst); //FAILES TO COMPILE delete tst; }
NathanOliver.. 7
std::vector::push_back
您使用的版本需要可复制对象,您的类不可复制.原因std::thread
是不可复制
thread(const thread&) = delete;
由于它是不可复制的,因此会删除类的默认复制构造函数.
要添加默认值test
,testvec
您可以使用std::vector::emplace_back
testvec.emplace_back();
或者通过在呼叫中构建一个临时的 push_back
testvec.push_back(test());
这将调用r值引用的重载 push_back()
您还需要删除构造函数和析构函数,因为它们会阻止自动创建您的类需要正常工作的移动构造函数.根据经验,如果您的类只包含POD类型或类似POD的类型(自己处理的对象),那么您不需要创建任何构造函数,因为编译器提供的类型将起作用.
std::vector::push_back
您使用的版本需要可复制对象,您的类不可复制.原因std::thread
是不可复制
thread(const thread&) = delete;
由于它是不可复制的,因此会删除类的默认复制构造函数.
要添加默认值test
,testvec
您可以使用std::vector::emplace_back
testvec.emplace_back();
或者通过在呼叫中构建一个临时的 push_back
testvec.push_back(test());
这将调用r值引用的重载 push_back()
您还需要删除构造函数和析构函数,因为它们会阻止自动创建您的类需要正常工作的移动构造函数.根据经验,如果您的类只包含POD类型或类似POD的类型(自己处理的对象),那么您不需要创建任何构造函数,因为编译器提供的类型将起作用.