#include
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,
}