不能被拷贝构造和拷贝赋值的类对象
A aobj1;
A aobj2(aobj1); // 拷贝构造,产生新的对象
A aobj3;
aobj3 = aobj2; // 赋值构造,不产生新的对象
如果想不能被拷贝构造 且 不能被拷贝赋值
- 采用delete
class A
{
public:
A() {}
A(const A& tmpobj) = delete; // c++11中增加
A& operator= (const A& tmpobj) = delete;
}
- 采用private,使得对象没办法调用这两个函数。
class A
{
public:
A() {}
private:
A(const A& tmpobj) {};
A& operator= (const A& tmpobj) {return *this;};
}
- 以上private方法仍然能通过类成员函数来调用拷贝构造和拷贝赋值构造,如果通过也不想让类成员函数调用这两个函数,则可以通过不写着两个函数的实现体来实现,也就是说只有定义,没有声明。
class A
{
public:
A() {}
~A() {}
private:
A(const A& tmpobj);
A& operator= (const A& tmpobj);
}
- 写一个noncopyable的类,然后让别的类继承它。
class noncopyable
{
protected: // 只允许本类和子类成员访问
noncopyable() {}
~noncopyable() {}
private:
noncopyable(const noncopyable& tmpobj);
noncopyable& operator= (const noncopyable& tmpobj);
}
class A : private noncopyable
{
A() {}
~A() {}
}
其实完全可以定义一个noncopyable的类,如上面所写,将两个拷贝构造变成私有成员,这时候如果想要写一个不能被拷贝和赋值拷贝的新类,可以直接私有继承noncopyable类。这样一来,继承自noncopyable的类在执行拷贝操作时会调用基类的拷贝操作,但是基类的拷贝操作是private的,因此无法调用,引发编译错误。
只有父类指针指向子类对象
或者父类引用绑定子类对象
这种多态形式的代码存在的时候,父类才有必要写一个虚析构函数。因此noncopyable没必要写虚析构函数。