抛出问题:
1
2
3
|
Long a = 4l; Long b = 4l; a == b //true |
1
2
3
|
Long a = 128l; Long b = 128l; a == b //false |
如果Long的值在[-127,128]之间,用“==”判断是否相等是没问题的,如果不在这个区间,是不能用“==”的,原因如下源码解释:
1
2
3
4
5
6
7
|
public static Long valueOf( long l) { final int offset = 128 ; if (l >= - 128 && l <= 127 ) { // will cache return LongCache.cache[( int )l + offset]; } return new Long(l); } |
如果不在[-127,128]之间,则会new一个新对象,自然“==”两个不同的对象,其结果必然是false了。
解决方案:
1、使用Long中的longValue()进行转换
1
2
3
|
Long a = 128l; Long b = 128l; a.longValue() == b.longValue() //true |
2、使用Long中的equals()
1
2
3
|
Long a = 128l; Long b = 128l; a.equals(b); //true |
下面是该方法源码:
1
2
3
4
5
6
|
public boolean equals(Object obj) { if (obj instanceof Long) { return value == ((Long)obj).longValue(); } return false ; } |
两个Long类型比较存在的坑
一般来说,两个基本数据类型比较用 “==” 就可以了,平时很少用Long类型比较。
但是最近写项目时遇到了两个Long类型比较,当时也是直接用的双等于,然而当debug时却发现代码执行到这两个Long类型比较判断时并没有进入这个判断体内,然后上网搜索相关的问题, 其实很简单,但是不知道的话就很很容易入坑。
解决方法具体如下:
可以让两个Long类型的变量分别调用 ==longValue()== 方法来实现就可以了。
代码:
1
2
3
4
5
|
Long a=...; Long b=...; if (a.longValue() == b.longValue()) { ...; } |
其实Long是java数据包装类的一种,以上属于包装类Long转化为基本数据类型long的情况,以下列举其它数据包装类拆箱转化为基本数据类型的情况:
Integer转为int,需要调用intValue()方法
Double转为double,需要调用doubleValue()方法
Float转为float,需要调用floatValue()方法
总结:
某包装类Xxx转为对应的基本数据类型时,则调用xxxValue()方法。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/zjl_pcw/article/details/79969183