-1
#include <iostream>
using namespace std;

class ClassA
{
  const int a;
  int b, c;
      public:
    ClassA(int x, int y):a(10)
    {
       b = x;
       c = y;
    }
    ClassA():a(10)
    {
    }
    void print()
    {
    cout << a << endl;
    }
};

int main()
{
  ClassA objA(10, 20);
  ClassA objB;
  objB = objA;
  objB.print();
  return 0;
}

在以下情况下,编译器不会创建复制赋值运算符:

  1. 类具有 const 类型或引用类型的非静态数据成员。
  2. 类具有一个类型的非静态数据成员,该类型具有不可访问的复制赋值运算符。
  3. 类派生自具有不可访问的复制赋值运算符的基类。

在上述情况下,我通过上述示例理解了情况 1。但我没有得到案例 2 和案例 3,所以请通过一些例子帮助我理解。

4

1 回答 1

1

案例2将是这样的:

class non_assignable { 
   // note: private
   non_assignable &operator=(non_assignable const &source);
};

class whatever { 
    non_assignable n;
};

案例 3 将类似于:

 class whatever : public non_assignable {};

在任何一种情况下,都不会自动生成一个复制赋值运算符,whatever因为它包含一个non_assignable成员/子对象,它有一个不可访问的(私有)复制赋值运算符。

于 2013-05-27T07:28:56.970 回答