zoukankan      html  css  js  c++  java
  • Java的数组堆溢出问题

    在写测试方法的时候,生成了一个数组,之后报了堆溢出错误,这样的报错一般来说只要有一些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数组的大小就会发现问题的所在。

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

    到这我们就会发现一个不起眼的数组竟然占了这么大的空间,所以之前开的1G的堆根本是杯水车薪。如果屏幕前的你也遇到了这个问题,不妨计算一下你开的数组占了多少的空间。

  • 相关阅读:
    leetcode-15 三数之和
    leetcode-113 路径之和
    leetcode-112 路径之和
    leetcode-1 两数之和
    leetcode-215 第k大元素
    leetcode 698 集合k划分
    编程之法之字符串
    LeetCode 830. Positions of Large Groups
    LeetCode 821. Shortest Distance to a Character
    LeetCode 213. House Robber II
  • 原文地址:https://www.cnblogs.com/keeya/p/9809067.html
Copyright © 2011-2022 走看看