String类型转Long类型

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


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


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


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


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

使用“==”的疑问

if (user.getId() == admin.getId()) {  
    return true; 
} else {
    return false;
}

两个Long型的ID之间的比较,结果却是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);
}

原来是因为Long中有一个静态的内部类LongCache,专门用于缓存-128至127之间的值,一共256个元素。
如果仅仅是缓存下来而不去使用那么就没有任何意义。valueOf(long l)就是使缓存派上用场的方法,它会判断传入的参数是否在-128-127之间,如果是则直接从缓存中返回对应的引用,否则新创建一个Long的实例。

使用equals

Long重写了equals方法,如下:

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

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

但是我们用longValue比较时容易忘记后面一个包装类调longValue方法
所以,最好还是使用equals进行比较。也可以直接用.longValue()比较



注意:

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


不然会报错,java.lang.NumberFormatException


2、其次,字符串长度也要限制,不然也会出错


比如:String s ="20160926120625100000",超过19位,就会出错,报java.lang.NumberFormatException

           String s ="2016092612062510000",不超过19位就不会

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

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

猜你喜欢

转载自blog.csdn.net/lhx_ldm/article/details/80691302