Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15496244
  • 博文数量: 2005
  • 博客积分: 11986
  • 博客等级: 上将
  • 技术积分: 22535
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-17 13:56
文章分类

全部博文(2005)

文章存档

2014年(2)

2013年(2)

2012年(16)

2011年(66)

2010年(368)

2009年(743)

2008年(491)

2007年(317)

分类: LINUX

2009-11-23 14:02:57

#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]

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