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 valueOf(long l) { final int offset = 128; if (l >= -128 && 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 instanceof Long) { return value == ((Long)obj).longValue(); } return false; }
java Long型和long型的比较大小
一、Long数据的大小的比较
对于Long类型的数据,这个数据是一个对象,所以对象不可以直接通过“>”,“==”,“<”的比较,如果要比较两个对象的是否相等的话,我们可以用Long对象的.equals()方法:
二、long数据的大小的比较
对于long类型的数据,这个数据是一个基本数据类型,不属于对象,所以可以直接通过“>”,“==”,“<”作比较
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/mai763727999/article/details/91800949