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