这个程序在两个不同情况下对int数组的错误表现不同

时间:2015-10-08 17:22:48

标签: java arrays out-of-memory

此程序中的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);
    }
}

3 个答案:

答案 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];   

在第二种情况下,结果s2097152一个有效的整数,并且在为数组中的整数分配内存时耗尽内存。

所以你要努力

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并解决问题。