類成員訪問運算符(->)可以被重載,但它比較麻煩它被定義用于為一個類賦予“指針”行為。運算符->必須是一個成員函數。如果使用了->運算符,返回類型必須是指針或者是類的對象。
運算符->通常與指針引用運算符 * 結合使用,用于實現“只能指針”的功能,這些指針是行為與正常指針相似的對象,唯一不同的是,當通過指針訪問對象時,他們會執行其他任務。當指針銷毀時或者當指針指向另一個對象時,會自動刪除對象。
間接引用運算符->可被定義為一個一元后綴運算符,也就是說,給一個類
class Ptr {//…X * operator->(); }
類Ptr的對象可用于訪問類X的成員,使用方法與指針的用法十分類似:
void f(Ptr p) {p -> m = 10; // (p.operator ->()) ->m = 10; }
語句p -> m 被解釋為(p.operator ->()) ->m = 10;
/*** membervis.cpp ***/ #include<iostream> #include<vector> using namespace std;class Obj {static int i,j; public:void f() const {cout << i++ << endl;}void g() const{cout << j++ << endl;} };int Obj::i = 10; int Obj::j = 12;class ObjContainer {vector<Obj*> a; public:void add(Obj* obj){a.push_back(obj);}friend class SmartPointer; };class SmartPointer {ObjContainer oc;int index; public:SmartPointer(ObjContainer& objc){oc = objc;index = 0;}bool operator++(){if(index >= oc.a.size() - 1) return false;if(oc.a[++index] == 0) return false;return true;}bool operator++(int){return operator++();}Obj* operator->() const {if(!oc.a[index]){cout << "Zero value";return (Obj*)0;}return oc.a[index];} };int main() {const int sz = 10;Obj o[sz];ObjContainer oc;for(int i = 0; i < sz; i++){oc.add(&o[i]);}SmartPointer sp(oc);do{sp->f();sp->g();}while(sp++);return 0; }
運行結果:
exbot@ubuntu:~/wangqinghe/C++/20190812$ g++ membervis.cpp -o membervis
exbot@ubuntu:~/wangqinghe/C++/20190812$ ./membervis
10
12
11
13
12
14
13
15
14
16
15
17
16
18
17
19
18
20
19
21