#include<stdio.h> void main() { int i=5; //printf("%d,%d,\n",i,i++); //输出 6,5, //printf("%d,%d,\n",i++,i); //输出 6,6, //printf("%d,%d,\n",i,++i); //输出 6,6, //printf("%d,%d,\n",++i,i); //输出 6,6, //printf("%d,%d,\n",i++,++i); //输出 6,7, //printf("%d,%d,\n",++i,i++); //输出 7,5, //printf("%d,%d,\n",i++,i++); //输出 6,5, //printf("%d,%d,\n",++i,++i); //输出 7,7, //由此得出:可变参数是从右到左计算的,并且后自增(i++)是先将i当前值保存,然后自增,接着继续处理左边的参数。而i和i前自增是先计算。计算结束后依次入栈,因此后自增打印出来的是i在从右向左计算过程中当前的I值,而i,++i最终输出的都是I的最终值。 因此: //printf("%d,%d,%d,%d,\n",++i,i++,++i,i); //输出 8,6,8,8, //printf("%d,%d,%d,%d,\n",++i,++i,++i,++i); //输出 9,9,9,9, //printf("%d,%d,%d,%d,\n",i++,i++,i++,i++); //输出 8,7,6,5, //printf("%d,%d,%d,%d,%d,\n",i++,++i,i,++i,i++); 8,9,9,9,5, }
原文地址:http://muyunzhe.blog.51cto.com/9164050/1627943