C++:实现复制构造函数和复制赋值运算符

bli*_*egz 17 c++ copy-constructor

在阅读了C++中的复制构造函数和复制赋值运算符之后,我尝试创建一个简单的例子.虽然下面的代码片段显然有用,但我不确定我是否正确地实现了复制构造函数和复制赋值运算符.能不能指出是否有任何错误/改进或更好的例子来理解相关概念.

class Foobase
{
    int bInt;

public:
    Foobase() {}

    Foobase(int b) { bInt = b;}

    int GetValue() { return bInt;}

    int SetValue(const int& val) { bInt = val; }
};


class Foobar
{
    int var;    
    Foobase *base;      

public:
    Foobar(){}

    Foobar(int v)
    {
        var = v;        
        base = new Foobase(v * -1);

    }

    //Copy constructor
    Foobar(const Foobar& foo)
    {       
        var = foo.var;
        base = new Foobase(foo.GetBaseValue());
    }

    //Copy assignemnt operator
    Foobar& operator= (const Foobar& other)
    {
        if (this != &other) // prevent self-assignment
        {
            var = other.var;
            base = new Foobase(other.GetBaseValue());

        }
        return *this;
    }

    ~Foobar()
    {
        delete base;
    }

    void SetValue(int val)
    {
        var = val;
    }

    void SetBaseValue(const int& val)
    {
        base->SetValue(val);
    }

    int GetBaseValue() const
    {
        return(base->GetValue());
    }

    void Print()
    {
        cout<<"Foobar Value: "<<var<<endl;
        cout<<"Foobase Value: "<<base->GetValue()<<endl;

    }   

};

int main()
{
    Foobar f(10);       
    Foobar g(f);  //calls copy constructor
    Foobar h = f; //calls copy constructor

    Foobar i;
    i = f;

    f.SetBaseValue(12);
    f.SetValue(2);    

    Foobar j = f = z; //copy constructor for j but assignment operator for f

    z.SetBaseValue(777);
    z.SetValue(77);

    return 1;
}
Run Code Online (Sandbox Code Playgroud)

Jam*_*lis 15

您的副本分配运算符未正确实现.被指定的对象泄漏其base指向的对象.

你的默认构造函数也是不正确的:它的叶子都basevar未初始化的,所以没有办法知道是否无论是有效的,在析构函数,当你打电话delete base;,不好的事情发生.

实现复制构造函数和复制赋值运算符以及知道您已正确完成的最简单方法是使用复制和交换习惯用法.