【More Effective C++】Item 6
Item 6:區別Increment和Decrement操作符的前置(prefix)和后置(postfix)形式
  前置和后置的區別主要在于函數參數不一樣,后置形式中多了一個int型的參數,在后置形式被調用時,編譯器會自動給該int型參數傳0值。其次在于前置和后置形式所返回的類型不同,前置返回一個引用,后置返回一個const對象。
  下面主要講解increment的前置和后置形式,decrement類似。
  //前置式:累加后取出(increment and fetch)
  UPInt&?UPInt::operator++() //    ?1
  { 
(*this)+=1;
return *this;
  }
  const?UPInt UPInt::operator++(int)?    //?2-3
  { 
UPInt oldValue=*this;?
++(*this);? //?4
renturn oldValue;
   }?
  首先,請看上面4處標紅的地方,這些都是我們需要特別注意的地方。
  1、前置返回的是引用 (&) 類型;
  2、后置返回的是 const 對象;之所以是const類型,是根據內置類型(int等)的++、--的規則來要求的。對于內置類型 i++++ 是不允許的(但是 ++++i 是允許的),所以我們為自定義類型重載的 ++、-- 也應該符合這個規則。如果我們不定義返回值類型為const,那么 i++++就可以轉化為 i.operator++(0) .operator(0); 得以合法執行,這是錯誤的。原因主要有兩點:a)不符合內置類型的規則;b)計算結果錯誤,因為第二個后置式操作沒有改變真正的對象的值,而是改變的返回對象的值。因此最好的辦法就是禁止非const返回類型合法化。
  3、后置有一個int型的參數,但是在函數體內并沒有動用其參數,是的,以為該int型參數的唯一目的只是為了區別前置式和后置式。但是,如果你在函數體內沒有使用函數的命名參數,許多編譯器都會給出警告,因此為了避免這類警告,一種常見的策略是:故意略去你不打算使用的參數的名稱,以上代碼就是實行的這個策略。
  4、這個是為了保證后置式和前置式的行為一致,才這樣做的。這個保證原則是:后置式increment和decrement操縱符的實現應以其前置式的兄弟為基礎。如此一來,你只要維護前置式,因為后置式會自動調整為一致的行為。
  從效率方面來看:推薦大家盡量使用前置式(prefix),而不是后置式(postfix)。
  因為后置式有臨時對象的構造和析構,尤其對于自定義類型,造成的影響更大。
轉載于:https://www.cnblogs.com/next-IT-direction/p/3599947.html
總結
以上是生活随笔為你收集整理的【More Effective C++】Item 6的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 线段树hdu1754
 - 下一篇: 公共的Controler,是给非授权的用