通过引用赋值对象,而不复制



下面的操作失败,因为我想要赋值的对象正在复制,然后销毁。所以我应该声明B::data作为一个指针,或者有一些更好的花哨的方式来分配引用而不是复制(我想避免触发医生)?

class B {
    class myContainer{
        myContainer()  {/* allocate memory */}
        ~myContainer() {/* free memory */}
        ...
    };
    myContainer data;
};
...
void foo() {
    B x;
    x.data = myContainer(...);  // creates a myContainer, *copies* to x.data, then destroys 
}

理想情况下,我不想使用new,因为我想在堆栈上分配myContainer(因此不必手动管理内存,这是在dr中自动释放的全部意义)。

我要做的是将data作为myContainer的参考。所以:

class B
{
  public:
    class myContainer
    {
      ... 
    };
    myContainer& data;
    B(myContainer& d) : data(d) {} 
};
void foo()
{
    B::myContainer a;
    B x(a); 
}

注意:在这种情况下,你需要myContainer的持续时间至少和B的一样长,所以如果你能预见到有人会这样做,那么在这种情况下不做事情是有很好的理由的:

B* bar()
{
   B::myContainer a;
   B *p = new B(a);
   return p;
}

现在,当bar结束时,a正在被破坏。但是在*p中仍然有对它的引用,所以当我们试图以某种方式使用p->data时,事情会变得非常奇怪。

相关内容

  • 没有找到相关文章