C++入門之談前置++與后置++的區(qū)別
剛剛接觸C++的新手同學(xué)們,往往會被前置++和后置++搞混。這個概念在C++中還是很重要的,把前置++和后置++弄明白是必須的。下面就給大家介紹前置++和后置++的區(qū)別。
前置++:
- type operator++();
后置++:
- const type operator++(int );
為了編譯器區(qū)分前置和后置++,C++規(guī)定后綴形式有一個int類型參數(shù) ,當函數(shù)被調(diào)用時,編譯器傳遞一個0做為int參數(shù)的值給該函數(shù)。不這樣規(guī)定,無法區(qū)分,因為都僅以自身對象為入?yún)ⅰ?/p>
下面是一個簡單的例子:
- class CInt {
- private :
- int m_value;
- //
- } ;
- CInt & CInt:: operator ++ ( ) // 前置的是沒有參數(shù)的,并且返回引用
- {
- this -> m_value += 1 ;
- return * this ;
- }
- const CInt CInt::peartor ++ (Int) // 后置的有一個匿名參數(shù),并且返回const值
- {
- CInt old = * this ;
- ++ ( * this );
- return old;
- }
上面的實現(xiàn)解釋了一個關(guān)鍵問題:前置比后置效率高 ,后置需要構(gòu)造臨時對象并返回。
那為什么前置和后置返回參數(shù)不同呢?
前置僅僅是對自身進行運算,并將自身返回,這樣外面可以直接對這個返回對象再進行操作 ,如
- (++it)->function()
后置因其返回的不是原來的對象,此時再進行額外操作,改變的是臨時對象的狀態(tài),并不異義 ,容易誤解。
那為什么不返回const &呢?因為不能這么做,返回引用將無效,臨時對象已經(jīng)不存在了。
所以后置返回const 對象即限制對此臨時對象進行誤操作,并顯式地告訴調(diào)用者此對象僅為原對象的副本。
另外還有一個原因:內(nèi)置int類型并不支持 i++++ .而如果后置++返回一個可修改的副本將與內(nèi)置int類型行為不同。故應(yīng)該禁止使用者對返回值進行修改。
希望通過以上內(nèi)容的介紹,能夠幫助到你。