Java примитивный макет массива в памяти
вот два образца, на которых я хотел бы основать свой вопрос (предполагая, что у вас есть JOL
здесь):
Layouter layout32Bits = new HotSpotLayouter(new X86_32_DataModel());
Layouter layout64BitsComp = new HotSpotLayouter(new X86_64_COOPS_DataModel());
и пример использования этого:
int [] ints = new int[10];
System.out.println(ClassLayout.parseInstance(ints, layout32Bits).toPrintable());
System.out.println(ClassLayout.parseInstance(ints, layout64BitsComp).toPrintable());
и вот два выхода:
[I object internals:
OFFSET SIZE TYPE DESCRIPTION VALUE
0 4 (object header) 09 00 00 00 (00001001 00000000 00000000 00000000) (9)
4 4 (object header) 00 00 00 00 (00000000 00000000 00000000 00000000) (0)
8 4 (object header) 10 1b 0c 1a (00010000 00011011 00001100 00011010) (437000976)
12 40 int [I.<elements> N/A
52 12 (loss due to the next object alignment)
Instance size: 64 bytes
Space losses: 0 bytes internal + 12 bytes external = 12 bytes total
[I object internals:
OFFSET SIZE TYPE DESCRIPTION VALUE
0 4 (object header) 09 00 00 00 (00001001 00000000 00000000 00000000) (9)
4 4 (object header) 00 00 00 00 (00000000 00000000 00000000 00000000) (0)
8 4 (object header) 10 1b 0c 1a (00010000 00011011 00001100 00011010) (437000976)
12 4 (object header) 01 00 00 00 (00000001 00000000 00000000 00000000) (1)
16 40 int [I.<elements> N/A
56 8 (loss due to the next object alignment)
Instance size: 64 bytes
Space losses: 0 bytes internal + 8 bytes external = 8 bytes total
Я в основном понимаю выход, то, что я не знаю, что это такое:
12 bytes external and 8 bytes external
В общем, объекты 8 bytes
выровнены, так зачем нужно добавлять больше прокладка чем?
Я знаю о некоторых вещах, которые как-то странно, первый связан с API, который использует JOL и второй имеет отношение к внутренним данным, которые должны быть скрыты.
Я также знаю, о этой, но это кажется не связанным, так как это означает внутренняя обивка.
может кто-нибудь пролить свет на это?
1 ответов
Instance size: 64 bytes
вычисляется для текущей конфигурации виртуальной машины, но вы явно указать разные (несовместимые) Layouter
.
разница между фактическим размером (рассчитывается с помощью Instrumentation.getObjectSize
) и ожидаемый размер (рассчитанный Layouter) будет рассматриваться как loss due to the next object alignment
.
посмотреть ClassLayout.java