今天突然发现以前一直没有注意语法,
如果定义了类
class P {
int a;
}
class Ptr {
P *p;
P *operator->() {return p;}
}
那么可以这样写
Ptr ptr;
ptr->a = 1;
这里ptr->a = 1 其实是 (ptr.operator -> ())->a = 1; ,那为什么ptr 可以转换为 ptr.operator->() ?
答案是:编译器在解析这段代码的操作有如下步骤:
1.如果ptr是一个指针,并且指向的对象存在名为a的成员,则编译器调用对象的成员a
2.否则,如果ptr是一个重载了操作符-> 类的对象,那么首先执行 ptr.operator->() 再在返回值上执行->的操作。
3.报错。