前缀增量和减量运算符:++ 和 --
语法
++ unary-expression –– unary-expression
备注
前缀递增运算符 (++) 向其操作数添加 1;此递增值是表达式的结果。操作数必须是类型不为 const 的左值。结果是与操作数相同类型的左值。
前缀递减运算符 (––) 与前缀递增运算符类似,只不过操作数将减少 1,并且结果是递减值。
前缀和后缀递增和递减运算符均会影响其操作数。它们之间的主要差异是递增或递减在表达式的计算中出现的顺序。在前缀形式中,将在表达式计算中使用值之前进行递增或递减,因此表达式的值与操作数的值不同。在后缀形式中,将在表达式计算中使用值之后进行递增或递减,因此表达式的值与操作数的值相同。例如,以下程序将打印“++i = 6”:
1
2
3
4
5
6
7
8
9
10
|
// expre_Increment_and_Decrement_Operators.cpp
// compile with: /EHsc
#include <iostream>
using namespace std;
int main() {
int i = 5;
cout << "++i = " << ++i << endl;
}
|
整型或浮动类型的操作数将按整数值 1 递增或递减。结果的类型与操作数类型相同。指针类型的操作数将按其所寻址对象的大小递增或递减。递增的指针将指向下一个对象;递减的指针将指向上一个对象。
由于增量和减量运算符具有副作用,因此在预处理器宏中使用带递增或递减运算符的表达式时会产生意外的结果。请看以下示例:
1
2
3
4
5
6
7
8
|
// 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 );
}
|
宏将扩展为:
1
|
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 类型。
以下代码演示了后缀递增运算符:
1
2
3
4
5
6
7
8
9
10
|
// 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;
}
|
不支持对枚举类型执行后递增和后递减操作:
1
2
3
|
enum Compass { North, South, East, West );
Compass myCompass;
for ( myCompass = North; myCompass != West; myCompass++ ) // Error
|