C++ 编程规范-不能被拷贝构造和拷贝赋值的类对象

不能被拷贝构造和拷贝赋值的类对象

A aobj1;
A aobj2(aobj1);  // 拷贝构造,产生新的对象
A aobj3;
aobj3 = aobj2;  // 赋值构造,不产生新的对象

如果想不能被拷贝构造 且 不能被拷贝赋值

  1. 采用delete
class A
{
public:
	A() {}
	A(const A& tmpobj) = delete;  // c++11中增加
	A& operator= (const A& tmpobj) = delete;
}
  1. 采用private,使得对象没办法调用这两个函数。
class A
{
public:
	A() {}
private:
	A(const A& tmpobj) {};
	A& operator= (const A& tmpobj) {return *this;};
}
  1. 以上private方法仍然能通过类成员函数来调用拷贝构造和拷贝赋值构造,如果通过也不想让类成员函数调用这两个函数,则可以通过不写着两个函数的实现体来实现,也就是说只有定义,没有声明。
class A
{
public:
	A() {}
	~A() {}
private:
	A(const A& tmpobj);
	A& operator= (const A& tmpobj);
}
  1. 写一个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没必要写虚析构函数。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值