C语言中的++和--运算符
++和--運算符分別是 += 1 和 -= 1 的簡寫。設計這樣兩個運算符的本意是方便程序員,但i++和++i使用不恰當有時候會造成混淆,反倒令剛入門的C程序員有點兒混亂。
如果i++或者++i單獨為一條指令,則效果并沒有什么區別,都是令i = i + 1;但是如果和其它的運算符結合,則二者還是有區別的。具體來說,i++ 是先使用 i,然后執行 i = i + 1;而 ++i 則是先執行? i = i + 1,然后再使用 i 。舉個例子看下:
int i = 0;
printf("i++ is: %d\n", i++); // 先使用i,即打印 i++ is: 0;然后i = i + 1,即i的值變成1
printf("i is: %d\n", i);???? // 打印 i is: 1
printf("++i is: %d\n", ++i); // 先對i自增,即i = i + 1,令 i 的值變成2;然后打印,即 ++i is: 2
printf("i is: %d\n", i); // 打印 i is: 2
上述代碼運行結果如下:
++ 或 -- 運算符如果和+=、-=、*=、\=運算符結合,就還需要考慮運算符的優先級,情況會稍微復雜一些。舉例如下:
int i = 0, j = 2;j *= i++;printf("i is: %d; j is: %d\n", i, j);上述代碼打印結果為:
在第二行代碼中,表達式 j *= i++,運算符++的優先級高于 *=,因此先計算 i++(先使用i,等到當前指令執行結束再自增 i ),當前時刻 i 的值為0,那么 j = j * 0,因此計算出 j = 0;賦值結束后,執行 i = i + 1,則此時 i = 1。
因此,接下來的輸出語句打印出來的結果就不難理解了: i is: 1; j is: 0
如果將上述示例中的 i++ 改為 ++i,則結果會有不同嗎?
int i = 0, j = 2;j *= ++i;printf("i is: %d; j is: %d\n", i, j);上述代碼打印結果為:
可以看出,i 的值仍然是1,先自增和后自增對于 i 而言效果是一樣的。但是 j 的值就不同了,++i 意味著先令 i 自增,也就是執行 i = i + 1,令 i = 1;然后,計算 j = j * 1,計算的結果為 j = 2 。
這樣,接下來的輸出語句打印出來的結果就是: i is: 1; j is: 2
總結
以上是生活随笔為你收集整理的C语言中的++和--运算符的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: deb 中标麒麟_中标麒麟6安装goog
- 下一篇: 失业三星期:我寻找第二份编程工作之路