今天学习Java的时候遇到了这样一个题:
检查程序,是否存在问题,如果存在指出问题所在,如果不存在,说明输出结果。
package algorithms.com.guan.javajicu;
public class Inc {
public static void main(String[] args) {
Inc inc = new Inc();
int i = 0;
inc.fermin(i);
i= i ++;
System.out.println(i);
}
void fermin(int i){
i++;
}
}
A. 0
B. 1
C. 2
D. 3
首先根据选项得知程序没有问题,分析这段代码,由于Java中基本数据类型是值传递,因此调用fermin()方法不会改变main()方法中定义的i的值。对于i = i++操作,i++这个表达式会返回i自增之前的值,因此虽然i的值先自增为1,但是左边的赋值操作又把旧值0赋给i,因此最终会输出0,答案为A。
分析完之后我想到之前学习C语言的时候也有自增运算符,于是我又用C写了一样的代码运行,发现结果产生了分歧:
在codeblocks 20.03中的结果为0,而在VS 2019中的结果却是1。
在网上查询时发现Java和C对于自增自减运算符似乎是有区别,Java中采用了中间变量缓存机制,而C语言中变量在每一次自增运算时,变量所对应内存区域的内容就被重写了。这个可以解释VS 2019中的输出结果,但不能解释codeblocks和一些其他C编译器中的输出结果。因此我猜测VS和codeblocks对于自增运算符和赋值运算符同时出现的情况的处理有不同之处。
对此有更好解释的朋友欢迎来评论。