我在检测两个数字的和/乘是否超过长整数的最大值时遇到问题。
示例代码:
long a = 2 * Long.MAX_VALUE;
System.out.println("long.max * smth > long.max... or is it? a=" + a);
这给了我-2
,虽然我希望它会抛出一个NumberFormatException
......
有没有一种简单的方法来完成这项工作?因为我有一些代码在嵌套的 IF 块中进行乘法运算或在循环中进行加法运算,我不想在每个 IF 或循环内添加更多的 IF。
编辑:哦,好吧,似乎另一个问题的答案最适合我的需要:https
:
//stackoverflow.com/a/9057367/540394 我不想装箱/拆箱,因为它增加了不必要的开销,而且这条路很短,这对我来说是一个巨大的优势。我将编写两个简短的函数来进行这些检查并返回最小或最大长度。
Edit2:根据我上面链接的答案,这是将 long 限制为其最小值/最大值的函数:
/**
* @param a : one of the two numbers added/multiplied
* @param b : the other of the two numbers
* @param c : the result of the addition/multiplication
* @return the minimum or maximum value of a long integer if addition/multiplication of a and b is less than Long.MIN_VALUE or more than Long.MAX_VALUE
*/
public static long limitLong(long a, long b, long c)
{
return (((a > 0) && (b > 0) && (c <= 0))
? Long.MAX_VALUE
: (((a < 0) && (b < 0) && (c >= 0)) ? Long.MIN_VALUE : c));
}
如果您认为这是错误的,请告诉我。