Java中最常用的方法是什么来验证从long转换为int不丢失任何信息?

这是我当前的实现:

public static int safeLongToInt(long l) {
    int i = (int)l;
    if ((long)i != l) {
        throw new IllegalArgumentException(l + " cannot be cast to int without changing its value.");
    }
    return i;
}

当前回答

这不是解决方案!

我的第一个方法是:

public int longToInt(long theLongOne) {
  return Long.valueOf(theLongOne).intValue();
}

但这只是将long类型转换为int类型,可能会创建新的long实例或从long池中检索它们。


的缺点

长。valueOf如果数字不在Long的池范围[-128,127]内,则创建一个新的Long实例。 intValue实现所做的仅仅是: 返回(int)值;

因此,这比直接将long类型转换为int类型还要糟糕。

其他回答

我想我会这么简单:

public static int safeLongToInt(long l) {
    if (l < Integer.MIN_VALUE || l > Integer.MAX_VALUE) {
        throw new IllegalArgumentException
            (l + " cannot be cast to int without changing its value.");
    }
    return (int) l;
}

我认为这比反复选角更清楚地表达了意图……但这有点主观。

注意,潜在的兴趣-在c#中,它只是:

return checked ((int) l);

使用谷歌Guava的int类,您的方法可以更改为:

public static int safeLongToInt(long l) {
    return Ints.checkedCast(l);
}

从链接的文档:

checkedCast checkedCast(长值) 如果可能,返回等于value的int值。 参数: Value - int类型范围内的任何值 返回: 等于value的int值 抛出: IllegalArgumentException -如果value大于Integer。MAX_VALUE或小于Integer。MIN_VALUE

顺便说一句,您不需要safeLongToInt包装器,除非您想保留它,以便在不进行大量重构的情况下更改功能。

另一个解决方案是:

public int longToInt(Long longVariable)
{
    try { 
            return Integer.valueOf(longVariable.toString()); 
        } catch(IllegalArgumentException e) { 
               Log.e(e.printstackstrace()); 
        }
}

我已经尝试了这样的情况下,客户端正在做一个POST和服务器DB只理解整数,而客户端有一个长。

这里有一个解决方案,以防你不关心值,以防它比需要的更大;)

public static int safeLongToInt(long l) {
    return (int) Math.max(Math.min(Integer.MAX_VALUE, l), Integer.MIN_VALUE);
}

BigDecimal:

long aLong = ...;
int anInt = new BigDecimal(aLong).intValueExact(); // throws ArithmeticException
                                                   // if outside bounds