在c ++中创建不可复制但可移动的对象

就一个问题。看看C ++ Boost库(特别是boost :: thread类)我最后想到:“如何创建一个定义无法复制但可以从函数返回的对象的类?” 那么考虑这个例子,boost :: thread类具有我之前提到的特性,所以可以这样做:
boost::thread make_thread();

void f()
{
    boost::thread some_thread=make_thread();
    some_thread.join();
}
那么这意味着对象boost :: thread无法复制,但是从函数返回,这是可能的。 这怎么可能???? 我想一定不能提供拷贝构造函数,但是如何处理函数返回?它不需要使用复制构造函数??? 谢谢     
已邀请:
这在C ++ 1x中是可能的,它通过右值引用提供移动语义。使用此功能,您可以分别实现移动和/或复制:
class my_class {
  private:
    data_t* data_;
  public:
    my_class(const my_class& rhs)      // copy constructor
     : data_(rhs.data_.clone())
    {}
    my_class(my_class&& rhs)           // move constructor
     : data_(rhs.data_)
    {
      rhs.data_ = NULL;
    }
    ~my_class() {delete data_;}        // noop if data_==NULL

    my_class& operator=(my_class rhs)  // copy assignment
    {
      this->swap(rhs);
    }
    my_class& operator=(my_class&& rhs)// move assignment
    {
      this->swap(rhs);
    }

    // ...
};
可以单独禁止复制和移动,因此您可以设置可以移动但不能复制的类。 当然,即使你的编译器还不支持移动语义(
std::auto_ptr
,所有移动而不是分配时的复制),有一些神奇的技巧可以让你这样做,所以这可能适用于
boost::thread
即使没有移动语义。     
如果您想在C ++ 03中执行此操作,这是C ++的高级主题。有关此示例,请参阅Howard Hinnants Unique_ptr C ++ 03仿真。 它基本上是通过滥用C ++重载决策中的几个细微规则来工作的,特别是非const引用不能绑定到右值临时值的规则,并且非const转换函数仍然可以在非const临时值上调用。 您也可以使用C ++ 03所使用的auto_ptr技术,但是由于auto_ptr允许您复制变量,但是从复制的对象中窃取资源(其他组对此有其他意见),因此可以看到它被几个组破坏了。     

要回复问题请先登录注册