前綴增量和減量運算符:++ 和 --
語法
++ unary-expression –– unary-expression
備注
前綴遞增運算符 (++) 向其操作數添加 1;此遞增值是表達式的結果。操作數必須是類型不為 const 的左值。結果是與操作數相同類型的左值。
前綴遞減運算符 (––) 與前綴遞增運算符類似,只不過操作數將減少 1,并且結果是遞減值。
前綴和后綴遞增和遞減運算符均會影響其操作數。它們之間的主要差異是遞增或遞減在表達式的計算中出現的順序。在前綴形式中,將在表達式計算中使用值之前進行遞增或遞減,因此表達式的值與操作數的值不同。在后綴形式中,將在表達式計算中使用值之后進行遞增或遞減,因此表達式的值與操作數的值相同。例如,以下程序將打印“++i = 6”:
// expre_Increment_and_Decrement_Operators.cpp// compile with: /EHsc#include <iostream>using namespace std;int main() { int i = 5; cout << "++i = " << ++i << endl;}
整型或浮動類型的操作數將按整數值 1 遞增或遞減。結果的類型與操作數類型相同。指針類型的操作數將按其所尋址對象的大小遞增或遞減。遞增的指針將指向下一個對象;遞減的指針將指向上一個對象。
由于增量和減量運算符具有副作用,因此在預處理器宏中使用帶遞增或遞減運算符的表達式時會產生意外的結果。請看以下示例:
// expre_Increment_and_Decrement_Operators2.cpp#define max(a,b) ((a)<(b))?(b):(a)int main(){ int i = 0, j = 0, k; k = max( ++i, j );}
宏將擴展為:
k = ((++i)<(j))?(j):(++i);
如果 i 大于或等于 j 或者比 j 小 1,則將遞增兩次。
System_CAPS_note注意
由于 C++ 內聯函數會消除副作用(如此處描述的副作用),并允許語言執行更全面的類型檢查,因此在很多情況下 C++ 內聯函數較宏更為可取。
后綴增量和減量運算符:++ 和 --
語法
postfix-expression
++
postfix-expression ––
備注
C++ 提供了前綴和后綴遞增和遞減運算符;兩者的區別在于,在后綴表示法中,運算符出現在 postfix-expression 之后,而在前綴表示法中,運算符出現在 expression 之前。以下示例顯示了一個后綴遞增運算符:
i++;
應用后綴遞增運算符 (++) 的效果是操作數的值增加一個適當類型的單位。同樣,應用后綴遞減運算符 (––) 的效果是操作數的值減少一個適當類型的單元。
值得注意的是,后綴遞增或遞減表達式的計算結果為應用各自的運算符之前的表達式的值。遞增或遞減運算在計算操作數之后發生。僅當在較大的表達式的上下文中發生后綴遞增或遞減運算時才會出現此問題。
當后綴運算符應用于函數參數時,在參數的值傳遞給函數之前,不能保證該值是遞增還是遞減。
將后綴遞增運算符應用于指向 long 類型的對象數組的指針實際上會將指針的內部表示形式增加 4。此行為會導致以前引用數組的第 n 個元素的指針引用第 (n+1) 個元素。
后綴遞增運算符和后綴遞減運算符的操作數必須是算術或指針類型的可修改的(非 const)左值。結果的類型與 postfix-expression 的類型相同,但不再是左值。
后綴遞增運算符的操作數也可以是 bool 類型,在這種情況下,將計算操作數,然后將其設置為 true)。后綴遞減運算符的操作數不能是 bool 類型。
以下代碼演示了后綴遞增運算符:
// expre_Postfix_Increment_and_Decrement_Operators.cpp// compile with: /EHsc#include <iostream>using namespace std;int main() { int i = 10; cout << i++ << endl; cout << i << endl;}
不支持對枚舉類型執行后遞增和后遞減操作:
enum Compass { North, South, East, West );Compass myCompass;for( myCompass = North; myCompass != West; myCompass++ ) // Error