一、過載一元運算子
首先,通過乙個例子來了解一下運算子過載:
#includeusing namespace std;class counter
counter(unsigned int i):count(i) {} //constructor,one arg
unsigned int get_count() const
counter operator ++ () //prefix
counter operator ++ (int) //postfix };
int main()
return distance(f,i);
}
1)如d3=d1+d2表示:運算子左側的d1為運算子所屬的物件(程式中的feet和inches),而運算子右側的d2為上面程式的引數dd;
2)由於有distance(f,i)則類中必須要兩個引數的建構函式才行。
3)enum;===static const int max=80
2)再看個例子(算術複製運算子):
#include #include using namespace std;上例中:過載+=運算子沒有返回值,所以只能單獨使用,即:d1+=d2;class distance
distance(int ft,float in):feet(ft),inches(in) {}
void getdist()
void showdist(int i) }
int main()
如果希望諸如 d3 = d1 += d2;這樣的表示式,那麼就是錯誤的,因為他缺少乙個返回值。
3.下標運算子【】
過載的下標運算子只有通過引用返回才會有用:因為這個運算子通常在等號左方使用,所以過載函式不得不通過引用返回。
這裡通過乙個安全陣列的例子來說明:
首先(不用過載):
#include using namespace std;
const int limit=100;
class safearay
return arr[n];
}};int main()
return arr[n];
}};int main()
{ safearay s1;
for (int j=0;j可以看出程式中使用: s1[j]=j*10 以及 int temp=s1[j] 來進行輸入輸出,變得更加方便簡單。同時,通過兩個程式的轉化,我們也能看出為什麼過載【】的時候要通過引用返回。
C 運算子過載 過載特殊運算子
賦值運算子用於同類物件間的相互賦值。賦值運算子只能被過載為類的非靜態成員函式,不能過載為友元函式和普通函式。對於使用者自定義的類而言,如果沒有過載賦值運算子,那麼c 編譯器會為該類提供乙個預設的過載賦值運算子成員函式。預設賦值運算子的工作方式是按位對拷,將等到右邊物件的非靜態成員拷貝給等號左邊的物件...
C 運算子過載賦值運算子
自定義類的賦值運算子過載函式的作用與內建賦值運算子的作用類似,但是要要注意的是,它與拷貝建構函式與析構函式一樣,要注意深拷貝淺拷貝的問題,在沒有深拷貝淺拷貝的情況下,如果沒有指定預設的賦值運算子過載函式,那麼系統將會自動提供乙個賦值運算子過載函式。賦值運算子過載函式的定義與其它運算子過載函式的定義是...
C 運算子過載轉換運算子
為什麼需要轉換運算子?大家知道對於內建型別的資料我們可以通過強制轉換符的使用來轉換資料,例如 int 2.1f 自定義類也是型別,那麼自定義類的物件在很多情況下也需要支援此操作,c 提供了轉換運算子過載函式 它使得自定義類物件的強轉換成為可能。轉換運算子的生命方式比較特別,方法如下 operator...