在C语言中,循环中使用i++表示先使用,再自增,使用++i表示先自增,再使用,而在pirntf()中i++和++i的运行机制却好像发生了一点变化,例如上图,如果按照“i++表示先使用,再自增,使用++i表示先自增,再使用”的说法,这题的答案应该是
0 1 2
0 1 3
0 2 2
1 1 2
1 2 3
1 2 2
1 1 3
0 2 3
但实际运行结果却是
困扰许久,查阅资料,终于找到了通俗易懂的解释,如下:
#define _CRT_SECURE_NO_WARNINGS 1 //vs2017中将scanf()printf()视为不安全函数,添加这行就可以正常使用
/*
解释:
函数printf从右到左压栈,然后将先读取到的放到栈底,最后读取到的放到栈顶,
处理时候从栈顶开始,所以i++的结果是从最右边开始处理的
但是C语言在处理 前置 和 后置 时的方式不同:
在处理 前置 时:将值放入临时量中,在输出时直接从临时量中取值
在处理 后置 时:等运算完成后,直接从变量地址中取值
*/
#include<stdio.h>
int main() {
int a = 0;
printf("第一组:%d,%d,%d\n", a++, a++, a++);//第一组
int b = 0;
printf("第二组:%d,%d,%d\n", b++, b++, ++b);//第二组
int c = 0;
printf("第三组:%d,%d,%d\n", c++, ++c, c++);//第三组
int d = 0;
printf("第四组:%d,%d,%d\n", ++d, d++, d++);//第四组
int e = 0;
printf("第五组:%d,%d,%d\n", ++e, ++e, ++e);//第五组
int f = 0;
printf("第六组:%d,%d,%d\n", ++f, ++f, f++);//第六组
int g = 0;
printf("第七组:%d,%d,%d\n", ++g, g++, ++g);//第七组
int h = 0;
printf("第八组:%d,%d,%d\n", h++, ++h, ++h);//第八组
return 0;
}