String类型转Long类型

String类型转Long类型开发中有遇到 Long 类型比较是否相等 比如 LongA 和 LongB 判断是否相等 当时习惯性的直接 A B nbsp nbsp 自测的话确实么有问题 但是测试那边测试就有问题 当时郁闷了一下然后换成了 A equals B 或 A longValue B longValue 都是正确的 nbsp nbsp 改完 bug 觉得需要看看是为什么 通过看 Long class 可以看出 nbsp nbsp 如果值在 128 127 之间

开发中有遇到Long类型比较是否相等,比如Long A和Long B判断是否相等,当时习惯性的直接A==B;

    自测的话确实么有问题,但是测试那边测试就有问题,当时郁闷了一下然后换成了A.equals(B)或A.longValue()==B.longValue()都是正确的;

    改完bug,觉得需要看看是为什么,通过看Long.class,可以看出

String类型转Long类型String类型转Long类型

    如果值在[-128, 127]之间,会放在缓存里面,而超过这个范围就要new一个新的对象,也就是说==不能判断对象是否相等。自测的话A或者B值设置的都比较小,而测试会考虑多方便的效果,所以就GG了。

在判断两个Long型数据是否相等的时候遇到了一个问题。

使用“==”的疑问

if (user.getId() == admin.getId()) { return true; } else { return false; }
Long id1 = 123L; Long id2 = 123L; System.out.println(id1 == id2); 输出: true

同是Long型,同是==,为什么结果不一样呢?
看看源代码:

private static class LongCache { private LongCache(){} static final Long cache[] = new Long[-(-128) + 127 + 1]; static { for(int i = 0; i < cache.length; i++) cache[i] = new Long(i - 128); } }
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); }

使用equals

Long重写了equals方法,如下:

public boolean equals(Object obj) { if (obj instanceof Long) { return value == ((Long)obj).longValue(); } return false; }

它是先通过.longValue()方法获取Long对象的基本类型long的值之后再做比较的。



注意:

1、首先,字符串内不能包含除数字之外的字符

原因是Long类型的最大值位Long.MAX_VALUE = ,大于这个值都会出错

Long类型的最小值位Long.MIN_VALUE=-,小于这个值也会报错



版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233698.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号