Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3515324
  • 博文数量: 1805
  • 博客积分: 135
  • 博客等级: 入伍新兵
  • 技术积分: 3345
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-19 20:01
文章分类

全部博文(1805)

文章存档

2017年(19)

2016年(80)

2015年(341)

2014年(438)

2013年(349)

2012年(332)

2011年(248)

分类:

2012-11-16 10:03:00

#include

int main(void)
{
    int i = 0;
    printf("%d,%d,%d\n", i++, i++, i++);
}

输出结果:
2,1,0
原因分析:
因为c函数参数作为一个整体执行的顺序是从右向左,所以会先处理最右端的参数,然后依次向左处理
所以结果为最右端的i++先被处理结果为0,然后++,接着1和2,这样就有了上面的结果.

#include

int main(void)
{
    int i = 0;
    printf("%d,%d,%d,%d,%d\n", ++i, ++i, i++, ++i, i++);
}
输出结果:
5,5,2,5,0
原因分析:
和上面的一样,唯一的不同是出现了++i,对于i++和++i是先加与后加的区别,但是在参数处理上则对应
如果是i++那么表示符合从右向左处理的前提下当即处理该参数,如果是++i,那么表示只是执行++i运算并不将结果作为参数结果,将参数位置压入堆栈,只有当所有参数从右向左处理完毕之后,从堆栈弹出所有因为延后操作语句而没有填入最终结果的参数位置,将最终执行的结果i,作为相应的参数值,填入进去[luther.gliethttp]

阅读(546) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~