Interface GroupLayout
- All Superinterfaces:
MemoryLayout
- All Known Subinterfaces:
StructLayout, UnionLayout
A compound layout that is an aggregation of multiple, heterogeneous
member layouts. There are two ways in which member layouts can be combined:
if member layouts are laid out one after the other, the resulting group layout is a
struct layout; conversely, if all member layouts are laid
out at the same starting offset, the resulting group layout is a
union layout.
- Implementation Requirements:
- This class is immutable, thread-safe and value-based.
- Sealed Class Hierarchy Graph:
- Since:
- 22
-
Nested Class Summary
Nested classes/interfaces declared in interface MemoryLayout
MemoryLayout.PathElement
-
Method Summary
Modifier and TypeMethodDescriptionReturns the member layouts of this group layout.withByteAlignment
(long byteAlignment) Returns a memory layout with the same characteristics as this layout, but with the given alignment constraint (in bytes).Returns a memory layout with the same characteristics as this layout, but with the given name.Returns a memory layout with the same characteristics as this layout, but with no name.Methods declared in interface MemoryLayout
arrayElementVarHandle, byteAlignment, byteOffset, byteOffsetHandle, byteSize, equals, hashCode, name, scale, scaleHandle, select, sliceHandle, toString, varHandle
Modifier and TypeMethodDescriptionarrayElementVarHandle
(MemoryLayout.PathElement... elements) Creates a var handle that accesses adjacent elements in a memory segment at offsets selected by the given layout path, where the accessed elements have this layout, and where the initial layout in the path is this layout.long
Returns the alignment constraint associated with this layout, expressed in bytes.long
byteOffset
(MemoryLayout.PathElement... elements) Computes the offset, in bytes, of the layout selected by the given layout path, where the initial layout in the path is this layout.byteOffsetHandle
(MemoryLayout.PathElement... elements) Creates a method handle that computes the offset, in bytes, of the layout selected by the given layout path, where the initial layout in the path is this layout.long
byteSize()
Returns the layout size, in bytes.boolean
Compares the specified object with this layout for equality.int
hashCode()
Returns the hash code value for this layout.name()
Returns the name (if any) associated with this layout.long
scale
(long offset, long index) Returnsoffset + (byteSize() * index)
.Returns a method handle that can be used to invokeMemoryLayout.scale(long, long)
on this layout.select
(MemoryLayout.PathElement... elements) Returns the layout selected from the provided path, where the initial layout in the path is this layout.sliceHandle
(MemoryLayout.PathElement... elements) Creates a method handle which, given a memory segment, returns a slice corresponding to the layout selected by the given layout path, where the initial layout in the path is this layout.toString()
Returns the string representation of this layout.varHandle
(MemoryLayout.PathElement... elements) Creates a var handle that accesses a memory segment at the offset selected by the given layout path, where the initial layout in the path is this layout.
-
Method Details
-
memberLayouts
List<MemoryLayout> memberLayouts()Returns the member layouts of this group layout.- API Note:
- the order in which member layouts are returned is the same order in which
member layouts have been passed to one of the group layout factory methods
(see
MemoryLayout.structLayout(MemoryLayout...)
andMemoryLayout.unionLayout(MemoryLayout...)
). - Returns:
- the member layouts of this group layout
-
withName
Returns a memory layout with the same characteristics as this layout, but with the given name.- Specified by:
withName
in interfaceMemoryLayout
- Parameters:
name
- the layout name- Returns:
- a memory layout with the same characteristics as this layout, but with the given name
- See Also:
-
withoutName
GroupLayout withoutName()Returns a memory layout with the same characteristics as this layout, but with no name.- Specified by:
withoutName
in interfaceMemoryLayout
- Returns:
- a memory layout with the same characteristics as this layout, but with no name
- See Also:
-
withByteAlignment
Returns a memory layout with the same characteristics as this layout, but with the given alignment constraint (in bytes).- Specified by:
withByteAlignment
in interfaceMemoryLayout
- Parameters:
byteAlignment
- the layout alignment constraint, expressed in bytes- Returns:
- a memory layout with the same characteristics as this layout, but with the given alignment constraint (in bytes)
- Throws:
IllegalArgumentException
- ifbyteAlignment
is not a power of twoIllegalArgumentException
- ifbyteAlignment
is less thanM
, whereM
is the maximum alignment constraint in any of the member layouts associated with this group layout
-