coder 真的需要自己動手去寫**,而不是僅僅看懂了規則就行的。
今天試著寫個複雜點的程式,剛開始的乙個結構體就就遇到了好多問題。
就拿這個來說吧。
1、首先說運算子過載,形式只有兩種:過載為類的成員函式 or 過載為類的友元函式。基本資料型別是不需要也無法進行運算子過載的,很簡單的道理,我卻沒想到。
2、接下來上面的x,y,z肯定是類裡面的資料成員啦,對應的是 過載為類的成員函式。這種過載的格式是:函式型別 operator 運算子(形參表) {}。
3、下面一種過載形式就是過載為類的友元函式。有2個引數,而過載為類的成員函式只有乙個引數,因為另乙個引數就是該物件本身。
4、const 修飾變數:對於其他變數沒什麼說的,對於指標,則可以分為2種:頂層const,常量指標,表示指標本身是個常量;底層const,指向常量的指標,表示所指的物件是個常量。區分:從右向左閱讀。
5、const 修飾函式:表示成員函式不會修改類的成員。所以不要在第二個過載函式後面加上const,否則會出現「非成員函式上不允許使用型別限定符」的錯誤。
6、起初不明白運算子過載,以為第一種宣告只適合於vector*scalar的情形,而不適合scalar*vector的情形。實際上,兩者都可以。
7、而對於下面的過載定義,要注意形參的順序。第乙個定義中,第乙個形參是物件本身,省略沒寫,第二個引數才是scalar;而若將第二個定義的形參位置對調後,兩個定義就相同了,出現這個錯誤。
運算子過載之過載型別運算子
普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...
運算子過載 賦值運算子的過載
有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...
運算子過載
c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...