RFR: 8295044: Implementation of Foreign Function and Memory API (Second Preview) [v6]

Paul Sandoz psandoz at openjdk.org
Mon Nov 7 19:11:15 UTC 2022


On Mon, 7 Nov 2022 15:00:02 GMT, Maurizio Cimadamore <mcimadamore at openjdk.org> wrote:

>> This PR contains the API and implementation changes for JEP-434 [1]. A more detailed description of such changes, to avoid repetitions during the review process, is included as a separate comment.
>> 
>> [1] - https://openjdk.org/jeps/434
>
> Maurizio Cimadamore has updated the pull request incrementally with one additional commit since the last revision:
> 
>   Make memory session a pure lifetime abstraction

src/java.base/share/classes/java/lang/foreign/Arena.java line 37:

> 35:  * This session is created with the arena, and is closed when the arena is {@linkplain #close() closed}.
> 36:  * Furthermore, all the native segments {@linkplain #allocate(long, long) allocated} by the arena are associated
> 37:  * with that session.

I think we can simplify the wording by saying an arena has a session:
Suggestion:

 * An arena is a {@linkplain AutoCloseable closeable} segment allocator that has a {@link #session() memory session}.
 * The arena's session is created when the arena is created, and is closed when the arena is {@linkplain #close() closed}.
 * All native segments {@linkplain #allocate(long, long) allocated} by the arena are associated
 * with its session.

src/java.base/share/classes/java/lang/foreign/Arena.java line 65:

> 63:      * The {@link MemorySegment#address()} of the returned memory segment is the starting address of the
> 64:      * allocated off-heap memory region backing the segment. Moreover, the {@linkplain MemorySegment#address() address}
> 65:      * of the returned segment is aligned according the provided alignment constraint.

Suggestion:

    /**
     * Creates a native memory segment with the given size (in bytes) and alignment constraint (in bytes).
     * The returned segment is associated with the arena's memory session.
     * The segment's {@link MemorySegment#address() address} is the starting address of the
     * allocated off-heap memory region backing the segment, and the address is 
     * aligned according the provided alignment constraint.

-------------

PR: https://git.openjdk.org/jdk/pull/10872


More information about the serviceability-dev mailing list