i和i 的區別

2021-06-21 07:14:11 字數 634 閱讀 8607

大家都應該知道i++和++i的區別,前者是先使用i的值,然後再增加1,而後者是先增加1然後再使用i的值。

但是i++和++i那個更好呢? 我們實現角度來看:前者是將i值加1後賦給i,然後返回i本身;而後者是先用個臨時變數儲存i值,然後將i值加1賦給i,然後返回臨時變數的值。

內建資料型別他們的效率差不多,看他們的彙編**就知道,我看的彙編**是vc的,其他編譯器不知道,還是得要看編譯器優化把。

而對於物件的++i和i++的效率,那明顯就是++i 要快,從實現角度我們看就是++i快,然後我們從實際**出發:

#includeusing namespace std;

class i

;i::i():m_i(0)

i::~i()

i::i(const i& iobj):m_i(iobj.m_i)

i& i::operator++()

i& i::operator=(const i &iobj)

i i::operator++(int)

int main(void)

結果是:

i 和 i的區別

當年上c 課的時候對於i 和 i的區別就稀里糊塗。後來沒注意也沒出過什麼問題。但是這個問題還是應該搞清楚。假如有乙個vector,值為 1,2,3,4,5,6,7 用以下程式輸出 i 0 while i 7 i 0 while i 7 cout beforei v i endl cout befor...

i 和 i的區別

很多朋友在學習基礎的時候很容易遇到過這個問題,i和i 到底有什麼區別?下面來詳細解釋一下。首先i 和 i單獨為一條語句時沒有任何區別 例如 int i 1 i 單獨為一條語句 system.out.println i i i 2 int i 1 i 單獨為一條語句 system.out.printl...

i 和 i的區別

i 與 i 的主要區別有兩個 1 i 返回原來的值,i 返回加1後的值。2 i 不能作為左值,而 i 可以。毫無疑問大家都知道第一點 不清楚的看下下面的實現 就了然了 我們重點說下第二點。首先解釋下什麼是左值 以下兩段引用自中文維基百科 右值引用 詞條 左值是對應記憶體中有確定儲存位址的物件的表示式...