++i 和 i++ 效率分析(C++)
引言
++i 和 i++ 在多數(shù)情況下產(chǎn)生的結(jié)果都一樣,但是它們的效率如何呢?
在C++中,它倆都用了運(yùn)算符++的重載,這里執(zhí)行效率上就有了些區(qū)別;
先說結(jié)論
++i 的效率比 i++ 的高,尤其在處理大量自定義類型的數(shù)據(jù)時(shí)會(huì)更明顯;
——————————————————————————————————————————————————————
分析
++i 的實(shí)現(xiàn)簡單說就是加1后返回結(jié)果就行了;
++的重載代碼:
i++ 多出來一步,因?yàn)樗窍仁褂卯?dāng)前值后加1,所以需要一個(gè)臨時(shí)的變量來存儲(chǔ)原來的值;
++的重載代碼:
通過代碼可以很輕易看出來i++多了一步,定義了一個(gè)新的變量存放原來的值;
總結(jié)
在實(shí)際編程中,
對于內(nèi)置數(shù)據(jù)類型(如int,char,指針等),編譯器會(huì)有優(yōu)化,所以 ++i 和 i++沒有太大區(qū)別;
而對于自定義的數(shù)據(jù)類型,就會(huì)有很大差別,C++中最典型的就是在STL中有關(guān)迭代器 iterator 的操作都是 ++i 的;
所以只要沒有強(qiáng)制的要求,就使用 ++i,反正效率提一點(diǎn)算一點(diǎn),就用最好的;
總結(jié)
以上是生活随笔為你收集整理的++i 和 i++ 效率分析(C++)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 76. 最小覆盖子串(滑动窗口)
- 下一篇: C++的几种遍历形式