此程序中的int数组出错 任何人都能解释为什么这两种情况的表现不同吗?
class MainOutOfMemoryError {
/*
case1:doesn't give me any error
static final int s = 1024 * 1024 * 1024 * 1024 * 1024;
public static void main(String[] args) {
// we cant declare local variables as static
int[] i = new int[s];
System.out.println(s);
}
*/
// case2:gives error
static final int SIZE = 2 * 1024 * 1024;
public static void main(String[] a) {
int[] i = new int[SIZE];
System.out.println(SIZE);
}
}
答案 0 :(得分:3)
来自您的评论
在Case1中,它显示sopln(s)打印0但在情况2中它打印实际尺寸,为什么?
在第一种情况下,发生整数溢出,s的结果为0
static final int s = 1024 * 1024 * 1024 * 1024 * 1024;
// s value is 0 because of overflow
这是一种写作
int[] i = new int[0];
在第二种情况下,结果s
是2097152
一个有效的整数,并且在为数组中的整数分配内存时耗尽内存。
所以你要努力
int[] i = new int[2097152];
尝试分配内存67108864
位。
我在这里有一些线索,是什么让你失去记忆,因为这些位等于8.388608MB
答案 1 :(得分:0)
对于您的第一个示例1024 * 1024 * 1024 * 1024 * 1024
,Google计算器会提供1.1258999e+15
。 Java Primitive Data Types教程说(部分)
int
:默认情况下,int数据类型是32位带符号的二进制补码整数,其最小值为-2 ^ 31,最大值为2 ^ 31-1
根据Google计算器,int
的最大值因此为2147483647.这意味着您的值溢出int
。这就是它起作用的原因。
如果你测试它,
int i = 1024 * 1024 * 1024 * 1024 * 1024;
System.out.println(i);
您会看到结果为0
。
答案 2 :(得分:0)
我认为你的意思恰恰相反:案例1给出了错误而第2个没有:
不是导致内存溢出的数组,而是变量SIZE,它是一个最大值约为20亿的int,将其更改为long并解决问题。