网站已经改版为Wordpress版本,这里是旧版本的快照,请不要在页面中留言.

C/C++ 自增自减运算符深入剖析

    

    C语言的自增++,自减--,运算符对于初学者来说一直都是个难题,甚至很多老手也会产生困惑,而且不同的编译器产生的结果可能也会有所不同。下面以Visual C++ 6.0 为例:

 

 

 #include <stdio.h>
  void main() /*主函数*/
  {
      int a,b,c,d;
      a=5;
      b=5;
      c=(a++)+(a++)+(a++);
      d=(++b)+(++b)+(++b);
      printf("a=%d,b=%d,c=%d,d=%d\n",a,b,c,d);
  }


  结果是什么?

 

 

自增自减运算符语法

 

  自增运算符 ++ 使操作数的值加1,其操作数必须为(可简单地理解为变量)。对于自增就是加1这一点,这点大家都不会有什么疑问。

  问题在于:++ 可以置于操作数前面,也可以放在后面,如:

  

    ++i;
  i++;


  ++i表示,i自增1后再参与其它运算;而i++ 则是i参与运算后,i的值再自增1。自减运算符--与之类似。

  

实例剖析

  下面我们通过一些实例来深入理解自增运算符的特性

  例一:


    int i=3;
      int j=4;
      i++;
      ++j;
      printf("%d, %d\n", i, j);


  对此,大家都不会有什么困惑,结果就是 4,5;下面我们来做一点小改动:

  

       int i=3;
      int j=4;
      int a = i++;
      int b = ++j;
      printf("%d, %d\n", a, b);


 

        结果又是多少呢?这里就开始体现出++前置与后置的区别了,结果是3,5。结合此例,我们回头再来理解一下“++前置:i自增1后再参与其它运算;++后置:i参与运算后,i的值再自增1。”很明显,a = i++;由于是先执行赋值运算,再自增,所以结果是a=3,i=4;而b = ++j;则因先自增,然后再赋值,所以b,j均为5。

 

  其实基本道理就这么简单了,但在更复杂点的情况下又会如何呢,请看:

  例二:


   int i=3;
      int j=4;
      int a = i++ + i++;
      int b = ++j + ++j;
      printf("%d, %d\n", a, b);


  问题又来了,i++ + i++是先自增一次,相加,再自增,然后赋值呢,还是先相加赋值然后自增两次呢。另外,++j又将如何表现呢?

  结果是:6,12

  这下明白了,原来 i++的理解应该是执行完整个表达式的其他操作后,然后才自增,所以例子中的a=3+3=6;而后i再自增2次,i=5;相反,++j是先自增然后再参加其它运算,所以b=6+6=12。

  

  例三:

     int i=3;
      int j=4;
      int a = i++ + i++ + i++;
      int b = ++j + ++j + ++j;
      printf("%d, %d\n", a, b);


  有人可能会说,这很简单,我全明白了:a=3+3+3=9,i=6,b=5+5+5=15,j=5.真的是这样吗?

  结果却是:9,19

  这下可好,又糊涂了。对于a = i++ + i++ + i++;我们已经没有疑问了,++后置就是执行完整个表达式的其他操作后,然后才自增,上例中也得到了验证,但 b = ++j + ++j + ++j;又该如何理解呢?

  原理表达式中除了预算法本身的优先级外,还有一个结合性问题。在++j + ++j + ++j;中,因为存在两个同级的+运算,根据+运算符的左结合性,在编译时,其实是先处理前面的(++j + ++j)这部分,然后再将此结果再和++j相加。

  

  再次强调:以上结果及解释出自Visual C++ 6.0编译器,但对于++这个问题是和编译器的解析有关的,不同厂家可能理解不一致,即使都是微软的产品,Visual C++和 Visual Studio 的结果也是不同的。


  • 标签:
  • C/C++自增
  • 运算符
网站已经改版为Wordpress版本,这里是旧版本的快照,请不要在页面中留言.