Item 26. Operator Function Lookup

Item 26. Operator Function Lookup

有时候Operator Function看起来像是成员操作符函数overload一个非成员操作符,但事实并非如此。这不是overloading,只是一种不同的查找算法。
class X {
  public:
    X operator %( const X & ) const; // binary modulus
    X memFunc1( const X & );
    void memFunc2();
    //...
};

X a, b, c;
a = b % c; // infix call to member operator %
a = b.operator %( c ); // member function call
a = b.memFunc1( c ); // another member function call

当使用member function call时,查找规则遵循 Member Function Lookup,使用infix call却有所不同,eg:
X operator %( const X &, int ); // non-member operator
//...
void X::memFunc2() {
     *this % 12; // calls non-member operator %
    operator %( *this, 12 ); // error! 参数个数不匹配,因为调用的是X ::operator %( const X & )        
}
对于infix operator call,成员函数和非成员函数编译器都会考虑到。因此对operator %进行infix call时,会找到 non-member operator。这并不属于overloading,只是一种不同的查找算法。调用non-infix call 函数operator %( *this, 12 )时,遵循标准函数查找规则,于是找到成员函数,发生了参数个数不正确的错误。

为了效率,infix calls 使用了一种退化的ADL:在决定overload哪一个函数时,只考虑infix operator的左边参数类域和全局域。 ADL包括了由参数所引入的namespaces 域。

转载于:https://www.cnblogs.com/aiwz/archive/2005/04/15/6333228.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值