今天来讲几个java中数字比较有意思的用法。
数字的可读性写法
对于整数,大家都知道可以使用int,long等表示,但是如果数字很大,比如千万或者亿,你要怎么写才能快速清晰地读出变量呢?
// 你能快速读出下面是几千万?还是几亿?intint1=21341763; longlong1=457813974947972L;
学过会计的同学知道很多数字,使用三位分节法可以提高数字可读性,比如21,341,763
。
其实,从JDK7开始,java支持在数字字面变量中加下划线,增加程序可读性,java编译器会自动去除这些下划线。
// 比如我们使用四位分级法intint2=2134_1763; longlong2=457_8139_7494_7972L;
除此之外,对于二进制和浮点数/双精度数,也支持这样的写法
// 浮点数写法floatff=3_33.1F; doubledd=3_3113.1345_63D; // 二进制写法,有利于我们转换成16进制等intbin=0b1101_1001;
Integer/Long/Short的缓存池问题
先看下面的例子:
// 下面的结果是什么?Integerint11=10; Integerint12=10; System.out.println("Integer 10 == 10? "+ (int11==int12)); Integerint21=newInteger(10); Integerint22=newInteger(10); System.out.println("new Integer(10) ? "+ (int21==int22)); Integerint31=128; Integerint32=128; System.out.println("Integer 128==128? "+ (int31==int32)); /** 结果:Integer 10 == 10? truenew Integer(10) ? falseInteger 128==128? true**/
如果有同学对于上面的第三个结果毫不惊讶,要么你是不知道Integer缓存池的小白,要么你是没有深入理解Integer缓存池大白(●—●)
机智的同学已经知道了,Integer中有一个IntegerCache,默认是缓存 -128~127 的整数,出现上面的结果,是因为是我修改了-Djava.lang.Integer.IntegerCache.high=<size>
的值上限。
但是对于第二个惊讶的同学,可能需要自己看一下源码,整数缓存池,只针对装箱过程,因此第二个例子的new Integer并不涉及装箱类型,自然产生的新对象,结果为false。
publicstaticIntegervalueOf(inti) { if (i>=IntegerCache.low&&i<=IntegerCache.high) returnIntegerCache.cache[i+ (-IntegerCache.low)]; returnnewInteger(i); }
对于Long和Short其实也有缓存池,他们的缓存池也是 -128~127 ,只是上下限不能通过配置修改。
不经意的错误
Integer是对象,因此可能为null,直接使用(integer == 1)
这种判断方式,涉及拆箱比较,而导致空指针异常,对新手程序员来说,是一个很容易忽略的错误。
今天的分析就到这里,希望对你有所帮助。
我是Pandas,专注Java编程实用技术分享,公众号
Java实用技术手册
和B站均有视频解说,欢迎来玩。 如果你觉得这篇文章有用,别忘了点赞+关注,一起进步!