关于Java中自增运算符的处理以及和C语言不同之处的小问题

今天学习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对于自增运算符和赋值运算符同时出现的情况的处理有不同之处。
对此有更好解释的朋友欢迎来评论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值