x521079 发表于 2020-1-21 11:47:59

自增自减运算符

++前置:i自增1后再参与其它运算
++后置:i参与运算后,i的值再自增1

#include <stdio.h>
void main()
{
      int i=3;
      int j=4;
      int a = i++;
      int b = ++j;
      printf("%d, %d, %d, %d\n", a, i, b, j);      //运行结果:3, 4, 5, 5
}
/***********************************************************************
分析原因:
a = i++;由于是先执行赋值运算,再自增,所以结果是a=3,i=4;
b = ++j;则因先自增,然后再赋值,所以b,j均为5.
***********************************************************************/
#include <stdio.h>
void main()
{
      int i=3;
      int j=4;
      int a = i++ + i++;
      int b = ++j + ++j;
      printf("%d, %d, %d, %d\n", a, i, b, j);      //运行结果:6, 5, 12, 6
}
/***********************************************************************
分析原因:
i++的理解应该是执行完整个表达式的其他操作后,然后才自增,所以例子中的a=3+3=6;
而后i再自增2次,i=5;
相反,++j是先自增2次,j=6;然后再参加其它运算,所以b=6+6=12.
***********************************************************************/
#include <stdio.h>
void main()
{
      int i=3;
      int j=4;
      int a = i++ + i++ + i++;
      int b = ++j + ++j + ++j;
      printf("%d, %d, %d, %d\n", a, i, b, j);      //运行结果:9, 6, 19, 7
}
/***********************************************************************
分析原因:
对于a = i++ + i++ + i++;我们已经没有疑问了,++后置就是执行完整个表达式的其他操作后,
然后才自增,上例中也得到了验证,但 b = ++j + ++j + ++j;又该如何理解呢?

原理表达式中除了预算法本身的优先级外,还有一个结合性问题。
在++j + ++j + ++j;中,因为存在两个同级的+运算,
根据+运算符的左结合性,在编译时,其实是先处理前面的(++j + ++j)这部分,
然后再将此结果再和++j相加。b=(6+6)+7注意最后一个++j是自增了3次的
具体过程参见汇编代码:
      int b = ++j + ++j + ++j;
  0040B7DD mov ecx,dword ptr
  0040B7E0 add ecx,1
  0040B7E3 mov dword ptr ,ecx // 第一个++j
  0040B7E6 mov edx,dword ptr
  0040B7E9 add edx,1
  0040B7EC mov dword ptr ,edx // 第二个++j
  0040B7EF mov eax,dword ptr
  0040B7F2 add eax,dword ptr // ++j + ++j
  0040B7F5 mov ecx,dword ptr
  0040B7F8 add ecx,1
  0040B7FB mov dword ptr ,ecx // 第三个++j
  0040B7FE add eax,dword ptr // ++j + ++j + ++j
  0040B801 mov dword ptr ,eax // 赋值给b

  int a = i++ + i++ + i++;
  0040B7B6 mov eax,dword ptr
  0040B7B9 add eax,dword ptr // i+i
  0040B7BC add eax,dword ptr // i+i+i
  0040B7BF mov dword ptr ,eax // 赋值给a
  0040B7C2 mov ecx,dword ptr
  0040B7C5 add ecx,1
  0040B7C8 mov dword ptr ,ecx // 第一次i++
  0040B7CB mov edx,dword ptr
  0040B7CE add edx,1
  0040B7D1 mov dword ptr ,edx // 第二次i++
  0040B7D4 mov eax,dword ptr
  0040B7D7 add eax,1
  0040B7DA mov dword ptr ,eax // 第三次i++
  果然不出所料。到此,++运算符前置后置的问题应该彻底解决了。
***********************************************************************/
#include <stdio.h>
void main()
{
      int i=1;
      int j=1;
      int a = i++ + i++ + i++ + i++ + i++ + i++ + i++; // 七个
      int b = ++j + ++j + ++j + ++j + ++j + ++j + ++j;
      printf("%d, %d\n", a, b);      //7, 36
      printf("%d, %d\n", i, j);      //8, 8
}
/***********************************************************************
分析原因:
  a = 1+1+1+1+1+1+1 = 7,i=8
  b = 3+3+4+5+6+7+8 = 36, j=8
***********************************************************************/


转载于https://fishc.com.cn/thread-43193-1-1.html
页: [1]
查看完整版本: 自增自减运算符