C++中不能重载的运算符

C++中的运算符:

名称 运算符
算数运算符 +、-、/、%、++、–
位操作运算符 &、
逻辑运算符 !、&&、
比较运算符 <、>、<=、>=、==、!=
赋值运算符 =、+=、-=、*=、/=、%=、
其他运算符 []、()、->、,、new、delete、new[]、delete[]、->*、sizeof

C++中不能重载的运算符有五个。,分别
为:“?:”“.”“::”“sizeof”“.*”。
重载:让操作符可以有新的语义,而不是更改语法,否则会引起混乱。
重载的部分规则:运算函数的参数至少有一个必须是类的对象或者是类的对象的引用。

我们来解释一下为什么这几个运算符不能进行重载。

(1)?:

假设可以重载,那么我们来看下列的代码:

exp1?exp2:exp3

该运算符的含义是执行exp2和exp3中的一个,假设重载了,就不可以保证执行一个还是两个,还是都没执行,该运算符的跳转性质就不复存在了。所以,“?:”不能被重载。

(2).

假设可以重载,我们可以假设一种情况,创建一个对象,调用该对象的函数。

class Y{
   publc:
      void fun();
};
class X{
   public:
      Y* p;
      Y& opterator.()
      {
          return *p;
      }
      void fun();
}
void g(X& x){
      x.fun();
}

这个例子中,x.fun()就不知道是调用哪一个fun函数了。
“.”运算符的含义是引用对象成员,然而被重载后就不能保证了,导致运算符意义的混淆。

(3)::

该运算符只是在编译的时候域解析,而没有运算参与。根据重载的规则,如果重载该运算符,就赋予了新的语义,可能会出现混淆。

(4)sizeof

不能被重载的原因主要是内部许多指针都依赖sizeof。

(5).*

引用指向类成员的指针

猜你喜欢

转载自blog.csdn.net/zwe7616175/article/details/80439870
今日推荐