Каков размер логической переменной в Java?

Неустранимая ошибка: допустимый размер памяти из XXX байт исчерпан (пытался выделить XXX байты)

Недостаточно памяти для запуска вашего скрипта. PHP достиг предела памяти и перестает его выполнять. Эта ошибка является фатальной, сценарий останавливается. Значение предела памяти можно настроить либо в файле php.ini, либо с помощью ini_set('memory_limit', '128 M'); в скрипте (который перезапишет значение, определенное в php.ini). Цель ограничения памяти заключается в том, чтобы не допустить, чтобы один скрипт PHP собирал всю доступную память и приводил к остановке всего веб-сервера.

Первое, что нужно сделать, это свести к минимуму объем памяти, необходимый вашему сценарию , Например, если вы читаете большой файл в переменной или извлекаете много записей из базы данных и сохраняете их все в массиве, которые могут использовать много памяти. Измените свой код, чтобы вместо этого читать строки по строке или извлекать записи базы данных по одному, не сохраняя их все в памяти. Это требует немного концептуального понимания того, что происходит за кулисами, и когда данные хранятся в памяти и в других местах.

Если эта ошибка возникла, когда ваш сценарий не выполнял интенсивную работу с памятью, вы вам нужно проверить свой код, чтобы узнать, есть ли утечка памяти. Функция memory_get_usage является вашим другом.

Вопросы, относящиеся:

89
задан ROMANIA_engineer 25 February 2015 в 05:42
поделиться

6 ответов

Это - зависимый виртуальной машины.

41
ответ дан Sotirios Delimanolis 24 November 2019 в 07:10
поделиться

Это зависит от виртуальной машины, но легко адаптировать код от подобный вопрос, спрашивающий о байтах в Java:

class LotsOfBooleans
{
    boolean a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, aa, ab, ac, ad, ae, af;
    boolean b0, b1, b2, b3, b4, b5, b6, b7, b8, b9, ba, bb, bc, bd, be, bf;
    boolean c0, c1, c2, c3, c4, c5, c6, c7, c8, c9, ca, cb, cc, cd, ce, cf;
    boolean d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, da, db, dc, dd, de, df;
    boolean e0, e1, e2, e3, e4, e5, e6, e7, e8, e9, ea, eb, ec, ed, ee, ef;
}

class LotsOfInts
{
    int a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, aa, ab, ac, ad, ae, af;
    int b0, b1, b2, b3, b4, b5, b6, b7, b8, b9, ba, bb, bc, bd, be, bf;
    int c0, c1, c2, c3, c4, c5, c6, c7, c8, c9, ca, cb, cc, cd, ce, cf;
    int d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, da, db, dc, dd, de, df;
    int e0, e1, e2, e3, e4, e5, e6, e7, e8, e9, ea, eb, ec, ed, ee, ef;
}


public class Test
{
    private static final int SIZE = 1000000;

    public static void main(String[] args) throws Exception
    {        
        LotsOfBooleans[] first = new LotsOfBooleans[SIZE];
        LotsOfInts[] second = new LotsOfInts[SIZE];

        System.gc();
        long startMem = getMemory();

        for (int i=0; i < SIZE; i++)
        {
            first[i] = new LotsOfBooleans();
        }

        System.gc();
        long endMem = getMemory();

        System.out.println ("Size for LotsOfBooleans: " + (endMem-startMem));
        System.out.println ("Average size: " + ((endMem-startMem) / ((double)SIZE)));

        System.gc();
        startMem = getMemory();
        for (int i=0; i < SIZE; i++)
        {
            second[i] = new LotsOfInts();
        }
        System.gc();
        endMem = getMemory();

        System.out.println ("Size for LotsOfInts: " + (endMem-startMem));
        System.out.println ("Average size: " + ((endMem-startMem) / ((double)SIZE)));

        // Make sure nothing gets collected
        long total = 0;
        for (int i=0; i < SIZE; i++)
        {
            total += (first[i].a0 ? 1 : 0) + second[i].a0;
        }
        System.out.println(total);
    }

    private static long getMemory()
    {
        Runtime runtime = Runtime.getRuntime();
        return runtime.totalMemory() - runtime.freeMemory();
    }
}

Для повторения это - VM-зависимый, но на моем ноутбуке Windows сборка JDK рабочего Sun 1.6.0_11 я получил следующие результаты:

Size for LotsOfBooleans: 87978576
Average size: 87.978576
Size for LotsOfInts: 328000000
Average size: 328.0

, Который предполагает, что булевские переменные могут в основном быть упакованы в байт каждый JVM Sun.

186
ответ дан Community 24 November 2019 в 07:10
поделиться

Фактическая информация, представленная булевым значением в Java, составляет один бит: 1 для истинного, 0 для лжи. Однако фактический размер логической переменной в памяти точно не определяется спецификацией Java. См. Примитивные типы данных в Java.

булев тип данных имеет только два возможных значения: истина и ложь. Используйте этот тип данных для простых флагов, которые отслеживают истинные/ложные условия. Этот тип данных представляет один бит информации, но ее "размер" не что-то, что это точно определяется.

31
ответ дан William Brendel 24 November 2019 в 07:10
поделиться

На ноте стороны...

, Если Вы думаете об использовании массива объектов Boolean, не делать. Используйте BitSet вместо этого - он имеет некоторые оптимизации производительности (и некоторые хорошие дополнительные методы, позволяя Вам получить следующий набор/сброс укусили).

21
ответ дан Matthew Schinckel 24 November 2019 в 07:10
поделиться

boolean значения компилируются в int тип данных в JVM. См. здесь .

2
ответ дан rics 24 November 2019 в 07:10
поделиться

Это не определено; выполнение вещей как предложенный Jon Skeet получит Вас приближение на данной платформе, но способ знать точно для определенной платформы состоит в том, чтобы использовать профилировщика.

0
ответ дан Lawrence Dol 24 November 2019 в 07:10
поделиться
Другие вопросы по тегам:

Похожие вопросы: