Gointerface接口声明实现及作用详解
283
2022-10-12
Java Long类型对比分析
java Long类型对比
在开发的到一个很基础的问题
在代码中,两个Long类型数据比较用“==”,结果有时候true有时候false,原本以为Long会自动转long然后再比较,不会是这里的错,找来找去实在找不到其他原因了,我就打印这两个Long类型出来看,果然是不相等,于是脸黑了一阵......
去查了一下资料,原来是这样:
Java 基本类型的包装类的大部分都实现了常量池技术,即Byte,Short,Integer,Long,Character;
这5种包装类默认创建了数值[-128,127]的相应类型的缓存数据,但是超出此范围仍然会去创建新的对象。
所以
当Long型的值超过了【-128,127】的时候,他会new一个新的对象,如果没有超过就会放到缓存中。
所以当Long型的值超过了【-128,127】的时候,“==”判断就不会相等了,可以理解为此时“==”比较的是两个对象的地址而不是值。
Long class源码:
public static Long valuehttp://Of(long l) {
final int offset = 128;
if (l >= -128tYhmg && l <= 127) { // will cache
return LongCache.cache[(int)l + offset];
}
return new Long(l);
}
正确的Long类型比较姿势:
1.使用Long的longValue()方法,转换成long值进行比较
Long a = 128l;
Long b = 128l;
a.longValue() == b.longValue(); //true
2.使用Long的equals()方法
Long a = 128l;
Long b = 128l;
a.equals(b); //true
Long class 源码:
public boolean equals(Object obj) {
if (obj tYhmginstanceof Long) {
return value == ((Long)obj).longValue();
}
return false;
}
java Long型和long型的比较大小
一、Long数据的大小的比较
对于Long类型的数据,这个数据是一个对象,所以对象不可以直接通过“>”,“==”,“<”的比较,如果要比较两个对象的是否相等的话,我们可以用Long对象的.equals()方法:
二、long数据的大小的比较
对于long类型的数据,这个数据是一个基本数据类型,不属于对象,所以可以直接通过“>”,“==”,“<”作比较
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~