Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
JDK 17 jdk.incubator.foreign.jmod - JDK Incubator Foreign
JDK 17 jdk.incubator.foreign.jmod is the JMOD file for JDK 17 HTTP Server module.
JDK 17 Incubator Foreign module compiled class files are stored in \fyicenter\jdk-17.0.5\jmods\jdk.incubator.foreign.jmod.
JDK 17 Incubator Foreign module compiled class files are also linked and stored in the \fyicenter\jdk-17.0.5\lib\modules JImage file.
JDK 17 Incubator Foreign module source code files are stored in \fyicenter\jdk-17.0.5\lib\src.zip\jdk.incubator.foreign.
You can click and view the content of each source code file in the list below.
✍: FYIcenter
⏎ jdk/internal/foreign/HeapMemorySegmentImpl.java
/* * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * * */ package jdk.internal.foreign; import jdk.incubator.foreign.MemorySegment; import jdk.internal.access.JavaNioAccess; import jdk.internal.access.SharedSecrets; import jdk.internal.misc.Unsafe; import jdk.internal.vm.annotation.ForceInline; import java.nio.ByteBuffer; import java.util.Objects; /** * Implementation for heap memory segments. An heap memory segment is composed by an offset and * a base object (typically an array). To enhance performances, the access to the base object needs to feature * sharp type information, as well as sharp null-check information. For this reason, many concrete subclasses * of {@link HeapMemorySegmentImpl} are defined (e.g. {@link OfFloat}, so that each subclass can override the * {@link HeapMemorySegmentImpl#base()} method so that it returns an array of the correct (sharp) type. */ public abstract class HeapMemorySegmentImpl<H> extends AbstractMemorySegmentImpl { private static final Unsafe UNSAFE = Unsafe.getUnsafe(); private static final int BYTE_ARR_BASE = UNSAFE.arrayBaseOffset(byte[].class); final long offset; final H base; @ForceInline HeapMemorySegmentImpl(long offset, H base, long length, int mask) { super(length, mask, ResourceScopeImpl.GLOBAL); this.offset = offset; this.base = base; } @Override abstract H base(); @Override long min() { return offset; } @Override abstract HeapMemorySegmentImpl<H> dup(long offset, long size, int mask, ResourceScopeImpl scope); @Override ByteBuffer makeByteBuffer() { if (!(base() instanceof byte[])) { throw new UnsupportedOperationException("Not an address to an heap-allocated byte array"); } JavaNioAccess nioAccess = SharedSecrets.getJavaNioAccess(); return nioAccess.newHeapByteBuffer((byte[]) base(), (int)min() - BYTE_ARR_BASE, (int) byteSize(), null); } // factories public static class OfByte extends HeapMemorySegmentImpl<byte[]> { OfByte(long offset, byte[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfByte dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfByte(this.offset + offset, base, size, mask); } @Override byte[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(byte[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_BYTE_INDEX_SCALE; return new OfByte(Unsafe.ARRAY_BYTE_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfChar extends HeapMemorySegmentImpl<char[]> { OfChar(long offset, char[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfChar dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfChar(this.offset + offset, base, size, mask); } @Override char[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(char[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_CHAR_INDEX_SCALE; return new OfChar(Unsafe.ARRAY_CHAR_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfShort extends HeapMemorySegmentImpl<short[]> { OfShort(long offset, short[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfShort dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfShort(this.offset + offset, base, size, mask); } @Override short[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(short[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_SHORT_INDEX_SCALE; return new OfShort(Unsafe.ARRAY_SHORT_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfInt extends HeapMemorySegmentImpl<int[]> { OfInt(long offset, int[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfInt dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfInt(this.offset + offset, base, size, mask); } @Override int[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(int[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_INT_INDEX_SCALE; return new OfInt(Unsafe.ARRAY_INT_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfLong extends HeapMemorySegmentImpl<long[]> { OfLong(long offset, long[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfLong dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfLong(this.offset + offset, base, size, mask); } @Override long[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(long[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_LONG_INDEX_SCALE; return new OfLong(Unsafe.ARRAY_LONG_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfFloat extends HeapMemorySegmentImpl<float[]> { OfFloat(long offset, float[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfFloat dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfFloat(this.offset + offset, base, size, mask); } @Override float[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(float[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_FLOAT_INDEX_SCALE; return new OfFloat(Unsafe.ARRAY_FLOAT_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } public static class OfDouble extends HeapMemorySegmentImpl<double[]> { OfDouble(long offset, double[] base, long length, int mask) { super(offset, base, length, mask); } @Override OfDouble dup(long offset, long size, int mask, ResourceScopeImpl scope) { return new OfDouble(this.offset + offset, base, size, mask); } @Override double[] base() { return Objects.requireNonNull(base); } public static MemorySegment fromArray(double[] arr) { Objects.requireNonNull(arr); long byteSize = (long)arr.length * Unsafe.ARRAY_DOUBLE_INDEX_SCALE; return new OfDouble(Unsafe.ARRAY_DOUBLE_BASE_OFFSET, arr, byteSize, defaultAccessModes(byteSize)); } } }
⏎ jdk/internal/foreign/HeapMemorySegmentImpl.java
Or download all of them as a single archive file:
File name: jdk.incubator.foreign-17.0.5-src.zip File size: 168767 bytes Release date: 2022-09-13 Download
⇒ JDK 17 jdk.incubator.vector.jmod - JDK Incubator Vector
2023-10-04, 5400👍, 0💬
Popular Posts:
How to download and install JDK (Java Development Kit) 1.3? If you want to write Java applications, ...
JDK 11 java.sql.jmod is the JMOD file for JDK 11 SQL (Structured Query Language) module. JDK 11 SQL ...
How to download and install JDK (Java Development Kit) 8? If you want to write Java applications, yo...
Apache BCEL Source Code Files are inside the Apache BCEL source package file like bcel-6.5.0-src.zip...
How to download and install ojdbc11.jar for Oracle 21c? ojdbc11.jar for Oracle 21c is a Java JDBC Dr...