public static void test(object obj) { system.out.println(obj.getclass()); }
(1) 精度小于int(或long)的数值运算的时候都回被自动转换为int(或long)后进行计算,运算结果为
char i = 'a';byte j = 2;test(i + j);//class java.lang.integerbyte i1 = 1;short j1 = 2;test(i1 + j1);//class java.lang.integer
(2)char、byte、short、int、long等整形数和float(或double)进行计算,会自动先提升float(double),在进行计算
int i2 = 1;float j2 = 1.5f;test(i2 + j2);//class java.lang.float
(3)float与double进行运算时,会float会先提升为double
float i3 = 1.2f;double j3 = 1;test(i3 + j3);//class java.lang.double
(4)a=a+1和a+=1的区别
如果问 a++ 和 ++a 的区别,估计很多都能回答上来。a++ 是先取 a 的值再自增 。而 中国航空大学++a 刚好相反,是先自增再取 a 的值。这里有点编程基础都可以理解,不做过多解释,但在 java 里面事情就真的这么简单吗?
int a = 1;a = a++;system.out.printl漾组词语n(a);
凭借自己所学,在不测试的情况下,你能给出答案吗?
第一次看见这个问题的时候,想当然的认为答案是:2。但残酷的事实告诉我,答案是:1。当时面对这个结果我是无法接受的,网上疯狂搜索这个答案的解释。限于当时知识的水平,只记住了这个结论,至于推导这个结论那些指令,一个也不能理解。今天看书遇见数据操作,就又想起了这个问题,就根据自己的知识水平,重新推导这个过程。
首先用 idea 打开生成的 class 文件。
很直观的告诉我们结果为 1 ,但这段代码只解释了 result,而没有解释 why ,继续用 javap -c 这个命令,结果如图。
以第一次遇见这道题的水准,勉强能看懂第一步的 java 代码,第二步的指令就彻底看不懂了。而现在我可以从这些指令里面分析结果了(这里需要分析的就前五行命令,后面指令为打印输出)。
iconst_1
将常量 1 压入操作数栈。这个操作是 int 值为 1~5 的时候。如果是 -128~127 这个范围是用的 bipush x (x 为实际数值)。 -2^15~2^15-1 这个范围是使用的 sipush x 这个命令(同上)。 -2^31~2^31-1 这个范围是使用的 ldc 这个命令。
istore_1
弹出操作数栈顶的数(此时为 1)并赋值给局部变量第一个元素即索引为 1 的 a。局部变量是采用的数组形式,索引为 0 的是 main()
的参数 args 。
iload_1
把局部变量索引为 1 的变量(这里是 a)压入操作数栈,此时栈顶元素为 1 。
incc 1,1(关键)
把局部变量索引为 1 的数加 1 ,此时 a 的值为 2。注意:这个结果没有压入操作数栈。
istore_1
弹出栈顶的元素(此时为 1)赋值给 a ,覆盖 a 为 2哈利 波特与阿兹卡班的囚徒 的结果。
相宜本草祛斑整个过程大致就是这样,来一幅图解释吧。
这个问题解决了,那么下面这段代码就好理解了。
int a = 1;a = ++a;system.out.println(a);
直接上截图吧
仔细对比一下,你会发现,两段代码的指令一模一样,但执行顺序有一点点区别, iinc 和 iload_1 副食店这两个命令的执行顺序变化了一下位置。你还记得这两条指令的含义吗?你还记得文章最开始说的区别吗?
以上为个人经验,希望能给大家一个参考,也希望大家多多支持www.887551.com。
本文发布于:2023-04-03 23:35:27,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/a6cd72ddaef12b2afadce26d2951cd95.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:java中a=a+1和a+=1的区别介绍.doc
本文 PDF 下载地址:java中a=a+1和a+=1的区别介绍.pdf
留言与评论(共有 0 条评论) |