- java.lang.Object
- 
- io.netty5.util.internal.PlatformDependent
 
- 
 public final class PlatformDependent extends Object Utility that detects various properties specific to the current runtime environment, such as Java version and the availability of thesun.misc.Unsafeobject.You can disable the use of sun.misc.Unsafeif you specify the system property io.netty5.noUnsafe.
- 
- 
Field SummaryFields Modifier and Type Field Description static booleanBIG_ENDIAN_NATIVE_ORDER
 - 
Method SummaryAll Methods Static Methods Concrete Methods Modifier and Type Method Description static intaddressSize()Return the address size of the OS. 4 (for 32 bits systems ) and 8 (for 64 bits systems).static longalign(long value, int alignment)static ByteBufferalignDirectBuffer(ByteBuffer buffer, int alignment)static ByteBufferallocateDirectNoCleaner(int capacity)Allocate a newByteBufferwith the givencapacity.static longallocateMemory(long size)static byte[]allocateUninitializedArray(int size)static intbitMode()Returns the bit mode of the current VM (usually 32 or 64.)static longbyteArrayBaseOffset()static booleancanEnableTcpNoDelayByDefault()Returnstrueif and only if it is fine to enable TCP_NODELAY socket option by default.static voidcopyMemory(byte[] src, int srcIndex, byte[] dst, int dstIndex, long length)static voidcopyMemory(byte[] src, int srcIndex, long dstAddr, long length)static voidcopyMemory(long srcAddr, byte[] dst, int dstIndex, long length)static voidcopyMemory(long srcAddr, long dstAddr, long length)static voidcopyMemory(Object src, long srcOffset, Object dst, long dstOffset, long length)static FilecreateTempFile(String prefix, String suffix, File directory)static ByteBufferdirectBuffer(long memoryAddress, int size, Object attachment)static longdirectBufferAddress(ByteBuffer buffer)static booleandirectBufferPreferred()Returnstrueif the platform has reliable low-level direct buffer access API and a user has not specified-Dio.netty5.noPreferDirectoption.static booleanequals(byte[] bytes1, int startPos1, byte[] bytes2, int startPos2, int length)Compare twobytearrays for equality.static intequalsConstantTime(byte[] bytes1, int startPos1, byte[] bytes2, int startPos2, int length)Compare twobytearrays for equality without leaking timing information.static longestimateMaxDirectMemory()Compute an estimate of the maximum amount of direct memory available to this JVM.static voidfreeDirectBuffer(ByteBuffer buffer)Try to deallocate the specified directByteBuffer.static voidfreeDirectNoCleaner(ByteBuffer buffer)This method MUST only be called forByteBuffers that were allocated viaallocateDirectNoCleaner(int).static voidfreeMemory(long address)static bytegetByte(byte[] data, int index)static bytegetByte(byte[] data, long index)static bytegetByte(long address)static bytegetByte(Object object, long fieldOffset)static chargetChar(Object object, long fieldOffset)static ClassLoadergetClassLoader(Class<?> clazz)Return theClassLoaderfor the givenClass.static ClassLoadergetContextClassLoader()Return the contextClassLoaderfor the currentThread.static doublegetDouble(Object object, long fieldOffset)static floatgetFloat(Object object, long fieldOffset)static intgetInt(byte[] data, int index)static intgetInt(int[] data, long index)static intgetInt(long address)static intgetInt(Object object, long fieldOffset)static intgetIntVolatile(long address)static longgetLong(byte[] data, int index)static longgetLong(long address)static longgetLong(long[] data, long index)static longgetLong(Object object, long fieldOffset)static ObjectgetObject(Object object, long fieldOffset)static shortgetShort(byte[] data, int index)static shortgetShort(long address)static shortgetShort(Object object, long fieldOffset)static ClassLoadergetSystemClassLoader()Return the systemClassLoader.static ThrowablegetUnsafeUnavailabilityCause()Return the reason (if any) whysun.misc.Unsafewas not available.static booleanhasAlignDirectByteBuffer()static booleanhasDirectBufferNoCleanerConstructor()static inthashCodeAscii(byte[] bytes, int startPos, int length)Calculate a hash code of a byte array assuming ASCII character encoding.static inthashCodeAscii(CharSequence bytes)Calculate a hash code of a byte array assuming ASCII character encoding.static booleanhasUnsafe()Returntrueifsun.misc.Unsafewas found on the classpath and can be used for accelerated direct memory access.static booleanisAndroid()Returnstrueif and only if the current platform is Androidstatic booleanisIkvmDotNet()static booleanisJ9Jvm()static booleanisOsx()Returntrueif the JVM is running on OSX / MacOSstatic booleanisUnaligned()trueif and only if the platform supports unaligned access.static booleanisWindows()Returntrueif the JVM is running on Windowsstatic booleanisZero(byte[] bytes, int startPos, int length)Determine if a subsection of an array is zero.static intjavaVersion()Return the version of Java under which this library is used.static longmaxDirectMemory()Returns the maximum memory reserved for direct buffer allocation.static booleanmaybeSuperUser()Returntrueif the current user may be a super-user.static <C> Deque<C>newConcurrentDeque()Returns a new concurrentDeque.static <T> Queue<T>newFixedMpscQueue(int capacity)Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!)static <T> Queue<T>newMpscQueue()Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!).static <T> Queue<T>newMpscQueue(int maxCapacity)Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!).static <T> Queue<T>newMpscQueue(int chunkSize, int maxCapacity)Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!).static <T> Queue<T>newSpscQueue()Create a newQueuewhich is safe to use for single producer (one thread!)static StringnormalizedArch()static Set<String>normalizedLinuxClassifiers()static StringnormalizedOs()static longobjectFieldOffset(Field field)static voidputByte(byte[] data, int index, byte value)static voidputByte(long address, byte value)static voidputByte(Object data, long offset, byte value)static voidputChar(Object data, long offset, char value)static voidputDouble(Object data, long offset, double value)static voidputFloat(Object data, long offset, float value)static voidputInt(byte[] data, int index, int value)static voidputInt(long address, int value)static voidputInt(Object data, long offset, int value)static voidputIntOrdered(long adddress, int newValue)static voidputLong(byte[] data, int index, long value)static voidputLong(long address, long value)static voidputLong(Object data, long offset, long value)static voidputObject(Object o, long offset, Object x)static voidputShort(byte[] data, int index, short value)static voidputShort(long address, short value)static voidputShort(Object data, long offset, short value)static ByteBufferreallocateDirectNoCleaner(ByteBuffer buffer, int capacity)Reallocate a newByteBufferwith the givencapacity.static longreallocateMemory(long address, long newSize)static introundToPowerOfTwo(int value)static voidsetMemory(byte[] dst, int dstIndex, long bytes, byte value)static voidsetMemory(long address, long bytes, byte value)static voidsetMemory(Object base, long offset, long length, byte value)static voidthrowException(Throwable t)Raises an exception bypassing compiler checks for checked exceptions.static Filetmpdir()Returns the temporary directory.static ObjectunwrapUnsafeOrNull()static longusedDirectMemory()Returns the current memory reserved for direct buffer allocation.static booleanuseDirectBufferNoCleaner()
 
- 
- 
- 
Method Detail- 
byteArrayBaseOffsetpublic static long byteArrayBaseOffset() 
 - 
hasDirectBufferNoCleanerConstructorpublic static boolean hasDirectBufferNoCleanerConstructor() 
 - 
allocateUninitializedArraypublic static byte[] allocateUninitializedArray(int size) 
 - 
isAndroidpublic static boolean isAndroid() Returnstrueif and only if the current platform is Android
 - 
isWindowspublic static boolean isWindows() Returntrueif the JVM is running on Windows
 - 
isOsxpublic static boolean isOsx() Returntrueif the JVM is running on OSX / MacOS
 - 
maybeSuperUserpublic static boolean maybeSuperUser() Returntrueif the current user may be a super-user. Be aware that this is just an hint and so it may return false-positives.
 - 
javaVersionpublic static int javaVersion() Return the version of Java under which this library is used.
 - 
canEnableTcpNoDelayByDefaultpublic static boolean canEnableTcpNoDelayByDefault() Returnstrueif and only if it is fine to enable TCP_NODELAY socket option by default.
 - 
hasUnsafepublic static boolean hasUnsafe() Returntrueifsun.misc.Unsafewas found on the classpath and can be used for accelerated direct memory access.
 - 
getUnsafeUnavailabilityCausepublic static Throwable getUnsafeUnavailabilityCause() Return the reason (if any) whysun.misc.Unsafewas not available.
 - 
isUnalignedpublic static boolean isUnaligned() trueif and only if the platform supports unaligned access.- See Also:
- Wikipedia on segfault
 
 - 
directBufferPreferredpublic static boolean directBufferPreferred() Returnstrueif the platform has reliable low-level direct buffer access API and a user has not specified-Dio.netty5.noPreferDirectoption.
 - 
maxDirectMemorypublic static long maxDirectMemory() Returns the maximum memory reserved for direct buffer allocation.
 - 
usedDirectMemorypublic static long usedDirectMemory() Returns the current memory reserved for direct buffer allocation. This method returns -1 in case that a value is not available.- See Also:
- maxDirectMemory()
 
 - 
tmpdirpublic static File tmpdir() Returns the temporary directory.
 - 
bitModepublic static int bitMode() Returns the bit mode of the current VM (usually 32 or 64.)
 - 
addressSizepublic static int addressSize() Return the address size of the OS. 4 (for 32 bits systems ) and 8 (for 64 bits systems).
 - 
allocateMemorypublic static long allocateMemory(long size) 
 - 
freeMemorypublic static void freeMemory(long address) 
 - 
reallocateMemorypublic static long reallocateMemory(long address, long newSize)
 - 
throwExceptionpublic static void throwException(Throwable t) Raises an exception bypassing compiler checks for checked exceptions.
 - 
freeDirectBufferpublic static void freeDirectBuffer(ByteBuffer buffer) Try to deallocate the specified directByteBuffer. Please note this method does nothing if the current platform does not support this operation or the specified buffer is not a direct buffer.
 - 
directBufferAddresspublic static long directBufferAddress(ByteBuffer buffer) 
 - 
directBufferpublic static ByteBuffer directBuffer(long memoryAddress, int size, Object attachment) 
 - 
getBytepublic static byte getByte(Object object, long fieldOffset) 
 - 
getShortpublic static short getShort(Object object, long fieldOffset) 
 - 
getCharpublic static char getChar(Object object, long fieldOffset) 
 - 
getIntpublic static int getInt(Object object, long fieldOffset) 
 - 
getFloatpublic static float getFloat(Object object, long fieldOffset) 
 - 
getLongpublic static long getLong(Object object, long fieldOffset) 
 - 
getDoublepublic static double getDouble(Object object, long fieldOffset) 
 - 
getIntVolatilepublic static int getIntVolatile(long address) 
 - 
putIntOrderedpublic static void putIntOrdered(long adddress, int newValue)
 - 
getBytepublic static byte getByte(long address) 
 - 
getShortpublic static short getShort(long address) 
 - 
getIntpublic static int getInt(long address) 
 - 
getLongpublic static long getLong(long address) 
 - 
getBytepublic static byte getByte(byte[] data, int index)
 - 
getBytepublic static byte getByte(byte[] data, long index)
 - 
getShortpublic static short getShort(byte[] data, int index)
 - 
getIntpublic static int getInt(byte[] data, int index)
 - 
getIntpublic static int getInt(int[] data, long index)
 - 
getLongpublic static long getLong(byte[] data, int index)
 - 
getLongpublic static long getLong(long[] data, long index)
 - 
putBytepublic static void putByte(long address, byte value)
 - 
putShortpublic static void putShort(long address, short value)
 - 
putIntpublic static void putInt(long address, int value)
 - 
putLongpublic static void putLong(long address, long value)
 - 
putBytepublic static void putByte(byte[] data, int index, byte value)
 - 
putBytepublic static void putByte(Object data, long offset, byte value) 
 - 
putShortpublic static void putShort(Object data, long offset, short value) 
 - 
putCharpublic static void putChar(Object data, long offset, char value) 
 - 
putIntpublic static void putInt(Object data, long offset, int value) 
 - 
putFloatpublic static void putFloat(Object data, long offset, float value) 
 - 
putLongpublic static void putLong(Object data, long offset, long value) 
 - 
putDoublepublic static void putDouble(Object data, long offset, double value) 
 - 
putShortpublic static void putShort(byte[] data, int index, short value)
 - 
putIntpublic static void putInt(byte[] data, int index, int value)
 - 
putLongpublic static void putLong(byte[] data, int index, long value)
 - 
objectFieldOffsetpublic static long objectFieldOffset(Field field) 
 - 
copyMemorypublic static void copyMemory(long srcAddr, long dstAddr, long length)
 - 
copyMemorypublic static void copyMemory(byte[] src, int srcIndex, long dstAddr, long length)
 - 
copyMemorypublic static void copyMemory(byte[] src, int srcIndex, byte[] dst, int dstIndex, long length)
 - 
copyMemorypublic static void copyMemory(Object src, long srcOffset, Object dst, long dstOffset, long length) 
 - 
copyMemorypublic static void copyMemory(long srcAddr, byte[] dst, int dstIndex, long length)
 - 
setMemorypublic static void setMemory(byte[] dst, int dstIndex, long bytes, byte value)
 - 
setMemorypublic static void setMemory(Object base, long offset, long length, byte value) 
 - 
setMemorypublic static void setMemory(long address, long bytes, byte value)
 - 
allocateDirectNoCleanerpublic static ByteBuffer allocateDirectNoCleaner(int capacity) Allocate a newByteBufferwith the givencapacity.ByteBuffers allocated with this method MUST be deallocated viafreeDirectNoCleaner(ByteBuffer).
 - 
reallocateDirectNoCleanerpublic static ByteBuffer reallocateDirectNoCleaner(ByteBuffer buffer, int capacity) Reallocate a newByteBufferwith the givencapacity.ByteBuffers reallocated with this method MUST be deallocated viafreeDirectNoCleaner(ByteBuffer).
 - 
freeDirectNoCleanerpublic static void freeDirectNoCleaner(ByteBuffer buffer) This method MUST only be called forByteBuffers that were allocated viaallocateDirectNoCleaner(int).
 - 
hasAlignDirectByteBufferpublic static boolean hasAlignDirectByteBuffer() 
 - 
alignDirectBufferpublic static ByteBuffer alignDirectBuffer(ByteBuffer buffer, int alignment) 
 - 
alignpublic static long align(long value, int alignment)
 - 
roundToPowerOfTwopublic static int roundToPowerOfTwo(int value) 
 - 
useDirectBufferNoCleanerpublic static boolean useDirectBufferNoCleaner() 
 - 
equalspublic static boolean equals(byte[] bytes1, int startPos1, byte[] bytes2, int startPos2, int length)Compare twobytearrays for equality. For performance reasons no bounds checking on the parameters is performed.- Parameters:
- bytes1- the first byte array.
- startPos1- the position (inclusive) to start comparing in- bytes1.
- bytes2- the second byte array.
- startPos2- the position (inclusive) to start comparing in- bytes2.
- length- the amount of bytes to compare. This is assumed to be validated as not going out of bounds by the caller.
 
 - 
isZeropublic static boolean isZero(byte[] bytes, int startPos, int length)Determine if a subsection of an array is zero.- Parameters:
- bytes- The byte array.
- startPos- The starting index (inclusive) in- bytes.
- length- The amount of bytes to check for zero.
- Returns:
- falseif- bytes[startPos:startsPos+length)contains a value other than zero.
 
 - 
equalsConstantTimepublic static int equalsConstantTime(byte[] bytes1, int startPos1, byte[] bytes2, int startPos2, int length)Compare twobytearrays for equality without leaking timing information. For performance reasons no bounds checking on the parameters is performed.The intreturn type is intentional and is designed to allow cascading of constant time operations:byte[] s1 = new {1, 2, 3}; byte[] s2 = new {1, 2, 3}; byte[] s3 = new {1, 2, 3}; byte[] s4 = new {4, 5, 6}; boolean equals = (equalsConstantTime(s1, 0, s2, 0, s1.length) & equalsConstantTime(s3, 0, s4, 0, s3.length)) != 0;- Parameters:
- bytes1- the first byte array.
- startPos1- the position (inclusive) to start comparing in- bytes1.
- bytes2- the second byte array.
- startPos2- the position (inclusive) to start comparing in- bytes2.
- length- the amount of bytes to compare. This is assumed to be validated as not going out of bounds by the caller.
- Returns:
- 0if not equal.- 1if equal.
 
 - 
hashCodeAsciipublic static int hashCodeAscii(byte[] bytes, int startPos, int length)Calculate a hash code of a byte array assuming ASCII character encoding. The resulting hash code will be case insensitive.- Parameters:
- bytes- The array which contains the data to hash.
- startPos- What index to start generating a hash code in- bytes
- length- The amount of bytes that should be accounted for in the computation.
- Returns:
- The hash code of bytesassuming ASCII character encoding. The resulting hash code will be case insensitive.
 
 - 
hashCodeAsciipublic static int hashCodeAscii(CharSequence bytes) Calculate a hash code of a byte array assuming ASCII character encoding. The resulting hash code will be case insensitive.This method assumes that bytesis equivalent to abyte[]but just usingCharSequencefor storage. The upper most byte of eachcharfrombytesis ignored.- Parameters:
- bytes- The array which contains the data to hash (assumed to be equivalent to a- byte[]).
- Returns:
- The hash code of bytesassuming ASCII character encoding. The resulting hash code will be case insensitive.
 
 - 
newMpscQueuepublic static <T> Queue<T> newMpscQueue() Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!).- Returns:
- A MPSC queue which may be unbounded.
 
 - 
newMpscQueuepublic static <T> Queue<T> newMpscQueue(int maxCapacity) Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!).
 - 
newMpscQueuepublic static <T> Queue<T> newMpscQueue(int chunkSize, int maxCapacity) Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!). The queue will grow and shrink its capacity in units of the given chunk size.
 - 
newSpscQueuepublic static <T> Queue<T> newSpscQueue() Create a newQueuewhich is safe to use for single producer (one thread!) and a single consumer (one thread!).
 - 
newFixedMpscQueuepublic static <T> Queue<T> newFixedMpscQueue(int capacity) Create a newQueuewhich is safe to use for multiple producers (different threads) and a single consumer (one thread!) with the given fixescapacity.
 - 
getClassLoaderpublic static ClassLoader getClassLoader(Class<?> clazz) Return theClassLoaderfor the givenClass.
 - 
getContextClassLoaderpublic static ClassLoader getContextClassLoader() Return the contextClassLoaderfor the currentThread.
 - 
getSystemClassLoaderpublic static ClassLoader getSystemClassLoader() Return the systemClassLoader.
 - 
unwrapUnsafeOrNullpublic static Object unwrapUnsafeOrNull() 
 - 
isJ9Jvmpublic static boolean isJ9Jvm() 
 - 
isIkvmDotNetpublic static boolean isIkvmDotNet() 
 - 
estimateMaxDirectMemorypublic static long estimateMaxDirectMemory() Compute an estimate of the maximum amount of direct memory available to this JVM.The computation is not cached, so you probably want to use maxDirectMemory()instead.This will produce debug log output when called. - Returns:
- The estimated max direct memory, in bytes.
 
 - 
normalizedArchpublic static String normalizedArch() 
 - 
normalizedOspublic static String normalizedOs() 
 - 
createTempFilepublic static File createTempFile(String prefix, String suffix, File directory) throws IOException - Throws:
- IOException
 
 
- 
 
-