Создать дамп Java, когда OutOfMemory - PullRequest
7 голосов
/ 08 февраля 2011

У меня есть программа, которая должна в конечном итоге генерировать OutOfMemory. Код программы:

public class VeryLargeObject implements Serializable {
    public static final int SIZE = 1 << 12;

    public String tag;
    public int[][] bigOne = new int[SIZE][SIZE];

    {
        // Initialize bigOne
        for(int i = 0; i < SIZE ; ++i) {
            for(int j = 0; j < SIZE; ++j) {
                bigOne[i][j] = (int) (Math.random() * 100);
            }
        }
    }

    public VeryLargeObject(String tag) {
        this.tag = tag;
    }

    public static void main(String args[]) {
        VeryLargeObject[] vla = new VeryLargeObject[1 << 12];
        for(int i = 0; i < Integer.MAX_VALUE; ++i) {
            vla[i] = new VeryLargeObject("aa");
        }
    }
}

Я запускаю программу со следующими параметрами:

java VeryLargeObject -Xms1024m -Xmx1024m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath="D:\workspace"

Программа завершается неудачно с OutOfMemory, но файл дампа не создается. У вас есть идеи, почему?

Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
        at VeryLargeObject.<init>(VeryLargeObject.java:14)
        at VeryLargeObject.main(VeryLargeObject.java:32)

Ответы [ 3 ]

16 голосов
/ 08 февраля 2011

Проблема в том, что -XX:HeapDumpPath определяет файл, а не путь.

-Xms1024m -Xmx1024m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath="c:\temp\dump2.hprof"

добавлено:

и bestsss тоже верно, поэтому вам нужно исправить обе "ошибки":

java -Xms1024m -Xmx1024m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath="c:\temp\dump2.hprof" VeryLargeObject
8 голосов
/ 08 февраля 2011

Для начала отбросьте опции XX и любые опции ДО VeryLargeObject, в противном случае вы передаете параметры в программу Java, а не в JVM

5 голосов
/ 08 февраля 2011

Я подозреваю, что jvm не может записать в путь и молча завершается неудачей Например, это должно быть имя файла в каталоге, который существует. Если у вас есть каталог D:\workspace, он потерпит неудачу. Если у вас есть D:\workspace\heap.hprof, это может сработать. Попробуйте сначала создать пустой файл с таким именем, чтобы убедиться, что вы можете сделать это.

...