1.++i
++i和等同于
1 i = i + 1;
2.i++
i++可以等同于
1 int temp = i; // 一个与i类型相同的临时变量 2 i = i + 1;
3.相同点和不同点
相同点:i最后都会被加1;
不同点:在i++中多了一个与i类型相同的临时变量,i++是右值,++i是左值。
例子1:
1 int a = 1, b = 2; 2 int *pt; 3 pt = &a; 4 5 pt++ = &b; // 错误 6 //上式等价于 7 //int *temp = pt; 8 //temp = &b; 给一个临时指针变量赋值无意义 9 //pt = pt + 1; 10 11 *pt++ = b; // 正确 12 //int *temp = pt; 13 // *temp = b; => a = b; 起到临时指针变量的作用 14 // pt = pt + 1;
例子2:
1 int fun() 2 { 3 int i = 0; 4 return i++; 5 } 6 // 等价于 7 int fun() 8 { 9 int i = 0; 10 int temp = i; 11 i = i+ 1; 12 return temp; 13 } 14 // 根据C11,i++和return之间存在序列点,i++在序列点之前,序列 15 //点之前的表达式及其副作用会被先计算,计算完之后return才会被执行
例子3:
1 #include <stdio.h> 2 int main(void) 3 { 4 int a = 5; 5 int *p = &a; 6 int b = (*p)++; //等价于b = a++; 即b = a; a = a + 1; 7 int c = ++(*p); //等价于c = ++a; 即a = a + 1; c = a; 8 printf("b = %d, c = %d\n", b, c); 9 printf("(*p)++ = %d, ++(*p) = %d\n", (*p)++, ++(*p)); 10 return 0; 11 } 12 例子输出结果: 13 b = 5, c = 7 ; 14 (*p)++ = 8, ++(*p) = 8
对于行9的情况应该避免,作为printf函数的参数(*p)++和 ++(*p)的计算没有先后顺序,依赖于编译器,因此在不同的编译器会产生不同的结果。