//有些情况下,想要明确地拒绝对象之间的拷贝,可以采用两种方式: //方式1: 将拷贝构造函数和赋值操作声明为private,且不去实现 class A { private: A(const A&); A& operator=(const A&); }; int main() { A a1; //报错:没有默认的构造函数, 一旦存在自定义的构造函数,即使是copy构造函数,编译器也不再会生成默认构造函数了. A a2 = a1; //报错:拷贝构造函数不可访问.return 0; }
//方式2: 去继承一个拷贝构造函数和赋值运算符函数为private的基类 class Uncopyable { private: //protected: //当以下两个函数为非private时,下面Test中操作不会报错. Uncopyable(const Uncopyable&); Uncopyable& operator=(const Uncopyable&); protected: Uncopyable(); ~Uncopyable(); }; class B : private Uncopyable { }; void Test() { B b1; B b2; b2 = b1; //报错:无法引用赋值操作; 这个才是调用的赋值操作符 B b3 = b1; //报错:无法引用拷贝构造函数; 注意此时调用的拷贝构造函数 }
原文地址:https://www.cnblogs.com/Stephen-Qin/p/12238434.html
时间: 2024-10-11 23:08:20