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).*
引用指向类成员的指针