在写测试方法的时候,生成了一个数组,之后报了堆溢出错误,这样的报错一般来说只要有一些JVM的基础都知道要用—Xmx、-Xms来开更大的堆,接下来看看我碰到的一个堆溢出的问题

在测试代码中开了一个50000*50000的int数组报错:

@Test
public void creatMPEM() {
    double packetLoss = 0.5;
    int[][] test = NetworkCodeTool.creatMPEM(50000, 50000, packetLoss);
    int one = 0;
    int zero = 0;
    double packageLossReal = 0;
    for (int i = 0; i < test.length; i++) {
        for (int j = 0; j < test[0].length; j++) {
            int temp =  test[i][j] == 1 ? one++ : zero++;
//                System.out.print(test[i][j]+" ");
        }
//            System.out.println();
    }

    Double sum = new Double(one + zero);
    packageLossReal = one / sum;
    System.out.println("期望丢包率:"+packetLoss);
    System.out.println("实际丢包率:"+packageLossReal);
}

public static int[][] creatMPEM(int n, int m, double packetLoss) {
    if (packetLoss >= 1){ throw new RuntimeException("the packetLoss is no means");}
    int[][] matrix = new int[n][m];
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            matrix[i][j] = Math.random() < packetLoss ? 1 : 0;
        }
    }
    return matrix;
}

报错信息:

java.lang.OutOfMemoryError: Java heap space

    at com.axin.communication.tools.compute.NetworkCodeTool.creatMPEM(NetworkCodeTool.java:20)
    at com.axin.communication.tools.compute.NetworkCodeToolTest.creatMPEM(NetworkCodeToolTest.java:9)

当你搜网上的解决方法时,往往就会看到说在虚拟机参数列上打上-Xms1024M,-Xmx1024M分配一个更大的堆空间,然而对上述的代码来说仍然会报错

其实我们遇到问题时下意识的动作就是去网上搜问题,往往没有有意识思考

实际上只要博主静下心来真正的算一算50000*50000 int数组的大小就会发现问题的所在。

计算一下5000050000数组所占的空间:1一个int类型的数占4个字节,总共占5000050000*4 = 10000000000 Byte ~=10G

到这我们就会发现一个不起眼的数组竟然占了这么大的空间,所以之前开的1G的堆根本是杯水车薪。

版权声明:本文为keeya原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/keeya/p/9809067.html