警惕java里面自增的陷阱
从我学C语言开始,老师就跟我们说,自增有两种,分别是i++和++i;其中i++先赋值后增加1,而++i是先增加1后赋值,对于这个理解,我近几年来一直都把他当成了真理来记住,然而在这几天的项目开发中,我发现我错了。
首先我们一起来看一下这个程序:
?
??
这个答案输出的j的值到底是多少呢?他循环了十次,每次都自增,是不是j的值就是10呢?答案可以很肯定的告诉你们,是0而不是10,这到底是为什么呢?这个就涉及到java的对这个的处理方式了。
首先,j++是一个表达式,是有返回值的,他的返回值就是j自加前的值。java对自加是这么处理的,首先把j的值拷贝到一个临时变量区,然后对j变量加1 ,最后返回临时变量区的值。程序第一次循环时的详细处理步骤如下:
?
步骤1 J V M 把 j 值(其值是0 )拷贝到临时变量区。
步骤2 j 值加1 ,这时候 j ?的值是1 。
步骤3 返回临时变量区的值,注意这个值是0 ,没修改过。
步骤4 返回值赋值给 j ,此时 j ?值被重置成0 。
“j = j + +??”这条语句可以按照如下代码来理解:
?
public static int mockAdd(intj){ // 先保存初始值 int temp = j; // 做自增操作 j = j+1; // 返回原始值 return temp;}?于是第一次循环后 j 的值还是0 ,其他9 次的循环也是一样的,最终你会发现 j的值始终没有改变,仍然保持着最初的状态。此例中的本意是希望 j 自增,所以想当然地认为赋值给自身就成了,不曾想掉到J a v a 自增的陷阱中了。解决方法很简单,只要把“j = j+ + ”修改为“j+ + ”即可。该问题在不同的语言环境有不同的实现: ?C + + 中“j =j + + ”与“j + + ”是等效的,而在P H P 中则保持着与J a v a 相同的处理方式。每种语言对自增的实现方式各不同,读者有兴趣可以多找几种语言测试一下,思考一下原理。
?
?