8298095: Refine implSpec for SegmentAllocator
Reviewed-by: mcimadamore
This commit is contained in:
parent
6dba2026d7
commit
35b60f925a
@ -77,8 +77,7 @@ import jdk.internal.javac.PreviewFeature;
|
|||||||
public interface SegmentAllocator {
|
public interface SegmentAllocator {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts a Java string into a UTF-8 encoded, null-terminated C string,
|
* {@return a new memory segment with a Java string converted into a UTF-8 encoded, null-terminated C string}
|
||||||
* storing the result into a memory segment.
|
|
||||||
* <p>
|
* <p>
|
||||||
* This method always replaces malformed-input and unmappable-character
|
* This method always replaces malformed-input and unmappable-character
|
||||||
* sequences with this charset's default replacement byte array. The
|
* sequences with this charset's default replacement byte array. The
|
||||||
@ -90,10 +89,9 @@ public interface SegmentAllocator {
|
|||||||
* the string, such as {@link MemorySegment#getUtf8String(long)}, the string
|
* the string, such as {@link MemorySegment#getUtf8String(long)}, the string
|
||||||
* will appear truncated when read again.
|
* will appear truncated when read again.
|
||||||
*
|
*
|
||||||
* @implSpec the default implementation for this method copies the contents of the provided Java string
|
* @implSpec The default implementation for this method copies the contents of the provided Java string
|
||||||
* into a new memory segment obtained by calling {@code this.allocate(str.length() + 1)}.
|
* into a new memory segment obtained by calling {@code this.allocate(str.length() + 1)}.
|
||||||
* @param str the Java string to be converted into a C string.
|
* @param str the Java string to be converted into a C string.
|
||||||
* @return a new native segment containing the converted C string.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateUtf8String(String str) {
|
default MemorySegment allocateUtf8String(String str) {
|
||||||
Objects.requireNonNull(str);
|
Objects.requireNonNull(str);
|
||||||
@ -101,198 +99,319 @@ public interface SegmentAllocator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given byte value.
|
* {@return a new memory segment initialized with the provided {@code byte} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfByte layout, byte value) {
|
default MemorySegment allocate(ValueLayout.OfByte layout, byte value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given char value.
|
* {@return a new memory segment initialized with the provided {@code char} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfChar layout, char value) {
|
default MemorySegment allocate(ValueLayout.OfChar layout, char value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given short value.
|
* {@return a new memory segment initialized with the provided {@code short} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfShort layout, short value) {
|
default MemorySegment allocate(ValueLayout.OfShort layout, short value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given int value.
|
* {@return a new memory segment initialized with the provided {@code int} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfInt layout, int value) {
|
default MemorySegment allocate(ValueLayout.OfInt layout, int value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given float value.
|
* {@return a new memory segment initialized with the provided {@code float} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfFloat layout, float value) {
|
default MemorySegment allocate(ValueLayout.OfFloat layout, float value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given long value.
|
* {@return a new memory segment initialized with the provided {@code long} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfLong layout, long value) {
|
default MemorySegment allocate(ValueLayout.OfLong layout, long value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given double value.
|
* {@return a new memory segment initialized with the provided {@code double} {@code value} as
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(ValueLayout.OfDouble layout, double value) {
|
default MemorySegment allocate(ValueLayout.OfDouble layout, double value) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
VarHandle handle = layout.varHandle();
|
VarHandle handle = layout.varHandle();
|
||||||
MemorySegment addr = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
handle.set(addr, value);
|
handle.set(seg, value);
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given address value.
|
* {@return a new memory segment initialized with the address of the provided {@code value} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
* <p>
|
||||||
* The address value might be narrowed according to the platform address size (see {@link ValueLayout#ADDRESS}).
|
* The address value might be narrowed according to the platform address size (see {@link ValueLayout#ADDRESS}).
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout)}.
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* Objects.requireNonNull(value);
|
||||||
|
* MemorySegment seg = allocate(Objects.requireNonNull(layout));
|
||||||
|
* seg.set(layout, 0, value);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @param value the value to be set on the newly allocated memory block.
|
* @param value the value to be set in the newly allocated memory segment.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(AddressLayout layout, MemorySegment value) {
|
default MemorySegment allocate(AddressLayout layout, MemorySegment value) {
|
||||||
Objects.requireNonNull(value);
|
Objects.requireNonNull(value);
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
MemorySegment segment = allocate(layout);
|
MemorySegment seg = allocate(layout);
|
||||||
layout.varHandle().set(segment, value);
|
layout.varHandle().set(seg, value);
|
||||||
return segment;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given byte elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code byte} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the byte elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfByte elementLayout, byte... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfByte elementLayout, byte... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given short elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code short} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the short elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfShort elementLayout, short... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfShort elementLayout, short... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given char elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code char} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the char elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfChar elementLayout, char... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfChar elementLayout, char... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given int elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code int} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the int elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfInt elementLayout, int... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfInt elementLayout, int... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given float elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code float} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the float elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfFloat elementLayout, float... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfFloat elementLayout, float... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given long elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code long} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the long elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfLong elementLayout, long... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfLong elementLayout, long... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout and initializes it with the given double elements.
|
* {@return a new memory segment with a {@linkplain MemorySegment#byteSize() byteSize()} of
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocateArray(layout, array.length)}.
|
* {@code E*layout.byteSize()} initialized with the provided {@code E} {@code double} {@code elements} as
|
||||||
|
* specified by the provided {@code layout} (i.e. byte ordering, alignment and size)}
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation is equivalent to:
|
||||||
|
* {@snippet lang=java :
|
||||||
|
* int size = Objects.requireNonNull(elements).length;
|
||||||
|
* MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
|
* MemorySegment.copy(elements, 0, seg, elementLayout, 0, size);
|
||||||
|
* return seg;
|
||||||
|
* }
|
||||||
|
*
|
||||||
* @param elementLayout the element layout of the array to be allocated.
|
* @param elementLayout the element layout of the array to be allocated.
|
||||||
* @param elements the double elements to be copied to the newly allocated memory block.
|
* @param elements the short elements to be copied to the newly allocated memory block.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocateArray(ValueLayout.OfDouble elementLayout, double... elements) {
|
default MemorySegment allocateArray(ValueLayout.OfDouble elementLayout, double... elements) {
|
||||||
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
return copyArrayWithSwapIfNeeded(elements, elementLayout, MemorySegment::ofArray);
|
||||||
@ -301,19 +420,21 @@ public interface SegmentAllocator {
|
|||||||
private <Z> MemorySegment copyArrayWithSwapIfNeeded(Z array, ValueLayout elementLayout,
|
private <Z> MemorySegment copyArrayWithSwapIfNeeded(Z array, ValueLayout elementLayout,
|
||||||
Function<Z, MemorySegment> heapSegmentFactory) {
|
Function<Z, MemorySegment> heapSegmentFactory) {
|
||||||
int size = Array.getLength(Objects.requireNonNull(array));
|
int size = Array.getLength(Objects.requireNonNull(array));
|
||||||
MemorySegment addr = allocateArray(Objects.requireNonNull(elementLayout), size);
|
MemorySegment seg = allocateArray(Objects.requireNonNull(elementLayout), size);
|
||||||
if (size > 0) {
|
if (size > 0) {
|
||||||
MemorySegment.copy(heapSegmentFactory.apply(array), elementLayout, 0,
|
MemorySegment.copy(heapSegmentFactory.apply(array), elementLayout, 0,
|
||||||
addr, elementLayout.withOrder(ByteOrder.nativeOrder()), 0, size);
|
seg, elementLayout.withOrder(ByteOrder.nativeOrder()), 0, size);
|
||||||
}
|
}
|
||||||
return addr;
|
return seg;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given layout.
|
* {@return a new memory segment with the given layout}
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(layout.byteSize(), layout.byteAlignment())}.
|
*
|
||||||
|
* @implSpec The default implementation for this method calls
|
||||||
|
* {@code this.allocate(layout.byteSize(), layout.byteAlignment())}.
|
||||||
|
*
|
||||||
* @param layout the layout of the block of memory to be allocated.
|
* @param layout the layout of the block of memory to be allocated.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(MemoryLayout layout) {
|
default MemorySegment allocate(MemoryLayout layout) {
|
||||||
Objects.requireNonNull(layout);
|
Objects.requireNonNull(layout);
|
||||||
@ -321,11 +442,13 @@ public interface SegmentAllocator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given element layout and size.
|
* {@return a new memory segment with the given {@code elementLayout} and {@code count}}
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(MemoryLayout.sequenceLayout(count, elementLayout))}.
|
*
|
||||||
|
* @implSpec The default implementation for this method calls
|
||||||
|
* {@code this.allocate(MemoryLayout.sequenceLayout(count, elementLayout))}.
|
||||||
|
*
|
||||||
* @param elementLayout the array element layout.
|
* @param elementLayout the array element layout.
|
||||||
* @param count the array element count.
|
* @param count the array element count.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
* @throws IllegalArgumentException if {@code elementLayout.byteSize() * count} overflows.
|
* @throws IllegalArgumentException if {@code elementLayout.byteSize() * count} overflows.
|
||||||
* @throws IllegalArgumentException if {@code count < 0}.
|
* @throws IllegalArgumentException if {@code count < 0}.
|
||||||
*/
|
*/
|
||||||
@ -338,10 +461,12 @@ public interface SegmentAllocator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given size.
|
* {@return a new memory segment with the given {@code byteSize}}
|
||||||
* @implSpec the default implementation for this method calls {@code this.allocate(byteSize, 1)}.
|
*
|
||||||
|
* @implSpec The default implementation for this method calls
|
||||||
|
* {@code this.allocate(byteSize, 1)}.
|
||||||
|
*
|
||||||
* @param byteSize the size (in bytes) of the block of memory to be allocated.
|
* @param byteSize the size (in bytes) of the block of memory to be allocated.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
* @throws IllegalArgumentException if {@code byteSize < 0}
|
* @throws IllegalArgumentException if {@code byteSize < 0}
|
||||||
*/
|
*/
|
||||||
default MemorySegment allocate(long byteSize) {
|
default MemorySegment allocate(long byteSize) {
|
||||||
@ -349,10 +474,10 @@ public interface SegmentAllocator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates a memory segment with the given size and alignment constraint.
|
* {@return a new memory segment with the given {@code byteSize} and {@code byteAlignment}}
|
||||||
|
*
|
||||||
* @param byteSize the size (in bytes) of the block of memory to be allocated.
|
* @param byteSize the size (in bytes) of the block of memory to be allocated.
|
||||||
* @param byteAlignment the alignment (in bytes) of the block of memory to be allocated.
|
* @param byteAlignment the alignment (in bytes) of the block of memory to be allocated.
|
||||||
* @return a segment for the newly allocated memory block.
|
|
||||||
* @throws IllegalArgumentException if {@code byteSize < 0}, {@code byteAlignment <= 0},
|
* @throws IllegalArgumentException if {@code byteSize < 0}, {@code byteAlignment <= 0},
|
||||||
* or if {@code byteAlignment} is not a power of 2.
|
* or if {@code byteAlignment} is not a power of 2.
|
||||||
*/
|
*/
|
||||||
@ -365,6 +490,7 @@ public interface SegmentAllocator {
|
|||||||
* <p>
|
* <p>
|
||||||
* The returned allocator throws {@link IndexOutOfBoundsException} when a slice of the provided
|
* The returned allocator throws {@link IndexOutOfBoundsException} when a slice of the provided
|
||||||
* segment with the requested size and alignment cannot be found.
|
* segment with the requested size and alignment cannot be found.
|
||||||
|
*
|
||||||
* @implNote A slicing allocator is not <em>thread-safe</em>.
|
* @implNote A slicing allocator is not <em>thread-safe</em>.
|
||||||
*
|
*
|
||||||
* @param segment the segment which the returned allocator should slice from.
|
* @param segment the segment which the returned allocator should slice from.
|
||||||
|
Loading…
Reference in New Issue
Block a user